亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

NW.js 簡(jiǎn)介與使用方法

 更新時(shí)間:2018年02月01日 09:12:06   投稿:mrr  
NW.js (原名 node-webkit)是一個(gè)基于 Chromium 和 node.js 的應(yīng)用運(yùn)行時(shí),通過(guò)它可以用 HTML 和 JavaScript 編寫(xiě)原生應(yīng)用程序.這篇文章主要介紹了NW.js 簡(jiǎn)介與使用,需要的朋友可以參考下

簡(jiǎn)介

NW.js (原名 node-webkit)是一個(gè)基于 Chromium 和 node.js 的應(yīng)用運(yùn)行時(shí),通過(guò)它可以用 HTML 和 JavaScript 編寫(xiě)原生應(yīng)用程序。它還允許您從 DOM 調(diào)用 Node.js 的模塊 ,實(shí)現(xiàn)了一個(gè)用所有 Web 技術(shù)來(lái)寫(xiě)原生應(yīng)用程序的新的開(kāi)發(fā)模式。

(1)以網(wǎng)絡(luò)最流行的技術(shù)編寫(xiě)原生應(yīng)用程序的新方法

(2)基于HTML5, CSS3, JS and WebGL而編寫(xiě)

(3)完全支持nodejs所有api及第三方模塊

(4)可以使用DOM直接調(diào)用nodejs模塊

(5)容易打包和分發(fā)

(6)支持運(yùn)行環(huán)境包括32位和64位的Window、Linux和Mac OS 

使用方法如下:

一、下載nw

1.下載 NW.js(官網(wǎng):http://nwjs.io/

這里面normal這個(gè)算是運(yùn)行時(shí)吧,sdk那個(gè)是一些工具箱,建議都下下來(lái)~

https://nwjs.io/downloads/

2.下載 Enigma Virtual Box(官網(wǎng):http://enigmaprotector.com/

二、配置 package.json 文件

{
 "name": "nw-demo",
 "version": "0.0.1",
 "main": "index.html"
}

更多的可用如下:

{
 "main": "app/index.html", 
 "name": "WeixinMenuEditor",
 "description": "使用nw.js封裝的一個(gè)微信公眾號(hào)菜單編輯器App",
 "version": "0.0.1",
 "keywords": [ "微信", "菜單編輯器" ], 
 "window": {
 "title": "微信菜單編輯器",
 "icon": "app/static/img/weixin_logo.jpg",
 "toolbar": true,
 "frame": true,
 "width": 1008,
 "height": 750,
 "position": "center",
 "min_width": 400,
 "min_height": 200
 },
 "webkit": {
 "plugin": true,
 "java": false,
 "page-cache": false 
 },
 "chromium-args" :"-allow-file-access-from-files"
}
  • title : 字符串,設(shè)置默認(rèn) title。
  • width/height : 主窗口的大小。
  • toolbar : bool 值。是否顯示導(dǎo)航欄。
  • icon : 窗口的 icon。
  • position :字符串。窗口打開(kāi)時(shí)的位置,可以設(shè)置為“null”、“center”或者“mouse”。
  • min_width/min_height : 窗口的最小值。
  • max_width/max_height : 窗口顯示的最大值。
  • resizable : bool 值。是否允許調(diào)整窗口大小。
  • always-on-top : bool 值。窗口置頂。
  • fullscreen : bool 值。是否全屏顯示。
  • show_in_taskbar : 是否在任務(wù)欄顯示圖標(biāo)。
  • frame : bool 值。如果設(shè)置為 false,程序?qū)o(wú)邊框顯示。
  • "chromium-args" :"-allow-file-access-from-files" 相當(dāng)于給谷歌瀏覽器添加啟動(dòng)參數(shù)一樣,這行代碼允許angularjs直接訪問(wèn)本地json文件。

三、生成exe

項(xiàng)目目錄如下:

將html項(xiàng)目壓縮成zip,并改名為nw,輸入以下命令

copy /b nw.exe+app.nw firstApp.exe

四、打發(fā)包發(fā)布

打開(kāi) Enigma Virtual Box 程序(enigmavb.exe),界面應(yīng)該是這樣的:

然后在 Enter Input File Name 處選擇上一步生成的 test.exe 文件,Enter Output Name 可以默認(rèn);

之后再點(diǎn)擊下面的 Add 按鈕,將 nwjs 文件夾(名稱(chēng)不一定是 nwjs ,就是最開(kāi)始第一步 NW.js 環(huán)境的那個(gè)文件夾)下除 nw.exe 和 test.nw 以及 test.exe 之外的所有文件加載上,然后點(diǎn)擊 Process ,等待執(zhí)行成功即可,這時(shí)候會(huì)在相應(yīng)的路徑下生成一個(gè)新的 .exe 文件(我們暫且叫做 newtest.exe),此時(shí)的 newtest.exe 文件即可在任意的 Windows 環(huán)境下運(yùn)行了,你可以拷貝給你的小伙伴去 Show 一下。

下面是nw使用過(guò)程中的一些坑

1.如果只希望當(dāng)前應(yīng)用獲取焦點(diǎn)才執(zhí)行快捷鍵,看看這個(gè)庫(kù)用js設(shè)置快捷鍵

// 加載本地ui庫(kù)
 var gui = require('nw.gui');
 var option = {
 key: "Ctrl+R",
 active: function () {
  alert("全局快捷鍵" + this.key + "按下");
 },
 failed: function (msg) {
  //創(chuàng)建快捷鍵失敗
  alert(msg);
 }
 };
 // 創(chuàng)建快捷鍵
 var shortcut = new gui.Shortcut(option);
 // 注冊(cè)全局快捷鍵
 gui.App.registerGlobalHotKey(shortcut);
 // 解除注冊(cè),在應(yīng)用結(jié)束的時(shí)候執(zhí)行
 gui.App.unregisterGlobalHotKey(shortcut);

2.nw.js不能對(duì)頁(yè)面多次刷新,各種不正常,這是由于刷新頁(yè)面后重新加載js文件對(duì)變量重新賦值引起的bug。 解決方案

nw.js 讀取和保存文件

<html>
<head>
 <meta charset="utf-8"/>
 <title>nw.js實(shí)現(xiàn)文件讀寫(xiě)</title>
</head>
<body>
 <input id="readFile" type="file" >讀取文件</input>
 <!-- 默認(rèn)文件名為filename.html -->
 <input id="writeFile" nwsaveas="filename.html" type="file">保存文件</input>
 <p></p>
 <script>
 //nw.js提供的讀寫(xiě)文件模塊
 var fs = require("fs");
 //讀文件
 var chooser = document.querySelector('#readFile');
 chooser.addEventListener("change", function (evt) {
  //用戶(hù)選擇的文件
  var filePath = this.value.toString();
  document.querySelector("p").innerHTML = "讀取文件從" + filePath;
  fs.readFile(filePath, function (err, data) {
   if (err) {
   layer.msg("讀取文件失敗! :" + err.message);
   return;
   } else {
   console.log(data);
   alert(data);
   }
  })
  });
 //寫(xiě)文件
 chooser = document.querySelector('#writeFile');
 chooser.addEventListener("change", function (evt) {
  //用戶(hù)選擇的文件
  var filePath = this.value.toString();
  document.querySelector("p").innerHTML = "寫(xiě)入文件到:" + filePath;
  //把hello寫(xiě)入文件
  fs.writeFile(filePath, "Hello!\n", function (err) {
   if (err) {
   alert("保存失敗!");
   }
  }); 
  });
 </script>
</body>
</html>

3.使用nwjs的'fs'直接保存cancas為本地圖片,在網(wǎng)上找到的方法都是彈出選擇框保存,但我需要直接保存圖片到指定路徑,不能彈出對(duì)話(huà)框讓用戶(hù)選擇。kailniris給了一個(gè)解決方案,可行,代碼如下:

var fs = require('fs');
var c = document.getElementById("myCanvas");
var ctx = c.getContext("2d");
ctx.moveTo(0, 0);
ctx.lineTo(200, 100);
ctx.stroke();
 <canvas id="myCanvas" width="200" height="100" style="border:1px solid #000000;">
 </canvas>
base64Data = c.toDataURL("image/png").replace(/^data:image\/png;base64,/, "")
fs.writeFile("c:/Dev/test.png", base64Data, 'base64', function (err) {
 if (err) {
 console.log("err", err);
 } else {
 return res.json({ 'status': 'success' });
 }
});

用html2canvas把html頁(yè)面轉(zhuǎn)換為圖片,再把圖片保存到本地。貼一下代碼(需要導(dǎo)入html2canvas.js和jquery):

//要保存圖片的文件路徑
  var filePath = templateDir + filename + '.html';
  //要保存的html頁(yè)面
  var editerDocument = window.editor.edit.iframe.get().contentWindow.document;
  html2canvas(editerDocument.body, {
  onrendered: function (canvas) {
   var base64Data = canvas.toDataURL("image/png").replace(/^data:image\/png;base64,/, "")
   var fs = require("fs");
   fs.writeFile(templateDir + filename + '.png', base64Data, 'base64', function (err) {
   if (err) {
    alert("保存模板失敗!");
   }
   $('#model_template_name').modal("hide");
   layer.msg("模板已保存為" + filename);
   });
  }
  });

4.在app.js里引用Node內(nèi)置模塊

//調(diào)用NodeJs內(nèi)置模塊
 $scope.fs = require('fs'); 
     //讀取配置文件
 $scope.readConfig = function () {
  try {
  var configStr = $scope.fs.readFileSync(config.weixin.path, 'utf8');
  console.log(configStr);
  var obj = eval('(' + configStr + ')');
  $scope.weixin.appid = obj.appid;
  $scope.weixin.appsecret = obj.appsecret;
  $scope.weixin.qrcodeurl = obj.qrcodeurl;
  }
  catch (e) {
  console.log(e);
  alert("讀取微信配置文件失敗");
  }
 }
 //寫(xiě)入配置文件
 $scope.writeConfig = function () {
  try {
  var configStr = JSON.stringify($scope.weixin);
  $scope.fs.writeFileSync(config.weixin.path, configStr, {encoding: 'utf8'});
  return true;
  }
  catch (e) {
  console.log(e);
  alert("寫(xiě)入微信配置文件失敗");
  return false;
  }
 }

5.引用第三方模塊wechat-api

//調(diào)用NodeJs第三方模塊
 $scope.wechatApi = require('wechat-api');
 $scope.query = function () {
  var api = new $scope.wechatApi($scope.weixin.appid, $scope.weixin.appsecret);
  api.getMenu(function (err, result) {
  if (err) {
   console.log(err);
   alert("查詢(xún)菜單異常");
  } else {
   load(result);
   $scope.$apply();//需要手動(dòng)刷新
  }
  });
 };

 更多詳細(xì)的可以參考 http://liuxp.me/nwjs/References/Window/ 中文文檔

總結(jié)

以上所述是小編給大家介紹的NW.js 簡(jiǎn)介與使用方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 使用Map處理Dom節(jié)點(diǎn)的方法詳解

    使用Map處理Dom節(jié)點(diǎn)的方法詳解

    本文淺析一下為什么Map(和WeakMap)在處理大量DOM節(jié)點(diǎn)時(shí)特別有用,文中的代碼示例介紹的非常詳細(xì),感興趣的小伙伴可以借鑒閱讀
    2023-05-05
  • 文本框(input)獲取焦點(diǎn)(onfocus)時(shí)樣式改變的示例代碼

    文本框(input)獲取焦點(diǎn)(onfocus)時(shí)樣式改變的示例代碼

    本篇文章主要是對(duì)文本框(input)獲取焦點(diǎn)(onfocus)時(shí)樣式改變的示例代碼進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-01-01
  • jqGrid讀取選擇的多行的某個(gè)屬性代碼

    jqGrid讀取選擇的多行的某個(gè)屬性代碼

    這篇文章主要介紹了jqGrid讀取選擇的多行的某個(gè)屬性實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-05-05
  • window.opener用法和用途實(shí)例介紹

    window.opener用法和用途實(shí)例介紹

    window.opener,是通過(guò)window.open打開(kāi)子窗體的父窗體的引用,下面為大家詳細(xì)介紹下其具體的使用方法,感興趣的朋友可以參考下
    2013-08-08
  • 原生js實(shí)現(xiàn)網(wǎng)頁(yè)頂部自動(dòng)下拉/收縮廣告效果

    原生js實(shí)現(xiàn)網(wǎng)頁(yè)頂部自動(dòng)下拉/收縮廣告效果

    本文主要介紹了原生js實(shí)現(xiàn)網(wǎng)頁(yè)頂部自動(dòng)下拉/收縮廣告效果的實(shí)例代碼。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • javascript中的五種基本數(shù)據(jù)類(lèi)型

    javascript中的五種基本數(shù)據(jù)類(lèi)型

    在javascript中申明變量使用的關(guān)鍵字都是var,這點(diǎn)與其他的編程語(yǔ)言不盡相同,但是javascript亦含有五種基本的數(shù)據(jù)類(lèi)型(也可以說(shuō)是簡(jiǎn)單數(shù)據(jù)類(lèi)型),它們分別是:Undefined,Null,Boolean,Number和String。還含有一種復(fù)雜數(shù)據(jù)類(lèi)型—Object。這里我們不談復(fù)雜數(shù)據(jù)類(lèi)型
    2015-08-08
  • 基于layPage插件實(shí)現(xiàn)兩種分頁(yè)方式淺析

    基于layPage插件實(shí)現(xiàn)兩種分頁(yè)方式淺析

    這篇文章主要為大家詳細(xì)介紹了基于layPage插件實(shí)現(xiàn)兩種分頁(yè)方式 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 微信小程序?qū)崿F(xiàn)瀑布流布局與無(wú)限加載的方法詳解

    微信小程序?qū)崿F(xiàn)瀑布流布局與無(wú)限加載的方法詳解

    瀑布流布局是我們?nèi)粘i_(kāi)發(fā)中經(jīng)常見(jiàn)到的一種頁(yè)面布局方式,下面這篇文章主要給大家介紹了微信小程序?qū)崿F(xiàn)瀑布流布局與無(wú)限加載的相關(guān)資料,文中給出了詳細(xì)介紹和示例代碼供大家參考學(xué)習(xí),需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • javascript 人物逼真行走,已完成

    javascript 人物逼真行走,已完成

    然后請(qǐng)分析下程序,我出以下題目,供牛牛們練手(RPG游戲開(kāi)發(fā) - 實(shí)戰(zhàn),不搞理論,著重程序?qū)崿F(xiàn)思路).
    2009-04-04
  • js數(shù)組刪除問(wèn)題(splice和delete的用法)

    js數(shù)組刪除問(wèn)題(splice和delete的用法)

    這篇文章主要介紹了js數(shù)組刪除問(wèn)題(splice和delete的用法),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02

最新評(píng)論