NW.js (以前はnode-webkitとして知られていました) は、Chromiumとnode.jsをベースにしたアプリケーションランタイムで、これを介してHTMLとJavaScriptでネイティブアプリケーションを作成できます。この記事では主にNW.jsの紹介と使い方について紹介します。が必要です。お友達は
はじめに
を参照してください。 NW.js (以前はnode-webkitとして知られていました) は、Chromiumとnode.jsに基づくアプリケーション ランタイムであり、これを介してネイティブ アプリケーションをHTMLとJavaScriptで作成できます。 。また、DOM から Node.js モジュールを呼び出すこともできるため、あらゆる Web テクノロジーを使用してネイティブ アプリケーションを作成するための新しい開発モデルが可能になります。
(1) インターネット上で最も人気のあるテクノロジーを使用してネイティブ アプリケーションを作成する新しい方法
(2) HTML5、CSS3、JS、WebGL に基づいて記述されています
(3) すべての Nodejs API とサードパーティ モジュールを完全にサポート
( 4) DOM を使用して、nodejs モジュールを直接呼び出すことができます
(5) パッケージ化と配布が簡単です
(6) 32 ビットおよび 64 ビットの Windows、Linux、Mac OS を含むオペレーティング環境をサポートします
利用方法は以下の通りです:
一、nw
をダウンロード 1. NW.jsをダウンロード(公式サイト:http://nwjs.io/)
ランタイム、SDK はいくつかのツールボックスです。すべてダウンロードすることをお勧めします~
https://nwjs.io/downloads/
2. Enigma Virtual Box をダウンロードします (公式 Web サイト: http://enigmaprotector) .com/)
2. パッケージの .json ファイルを設定します
{ "name": "nw-demo", "version": "0.0.1", "main": "index.html" }
さらに多くのものが以下のように利用可能です:
{ "main": "app/index.html", "name": "WeixinMenuEditor", "description": "使用nw.js封装的一个微信公众号菜单编辑器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: 文字列、デフォルトのタイトルを設定します。
幅/高さ: メインウィンドウのサイズ。
ツールバー: ブール値。ナビゲーションバーを表示するかどうか。
アイコン: ウィンドウのアイコン。
位置 : 文字列。ウィンドウを開いたときの位置を「null」「center」「mouse」から設定できます。
min_width/min_height: ウィンドウの最小値。
max_width/max_height: ウィンドウに表示される最大値。
sizeable : ブール値。ウィンドウのサイズ変更を許可するかどうか。
always-on-top : ブール値。上部に窓。
全画面: ブール値。全画面表示するかどうか。
show_in_taskbar : タスクバーにアイコンを表示するかどうか。
frame : ブール値。 false に設定すると、プログラムは枠なしで表示されます。
"chromium-args" :"-allow-file-access-from-files" は、Google Chrome に起動パラメータを追加することと同等であり、angularjs がローカルの json ファイルに直接アクセスできるようになります。
3. exeを生成します
プロジェクトディレクトリは次のとおりです:
HTMLプロジェクトをzipに圧縮し、名前をnwに変更し、次のコマンドを入力します
copy /b nw.exe+app.nw firstApp.exe
4.パッケージ
Enigma Virtual Box プログラム (enigmavb.exe) を開きます。インターフェイスは次のようになります:
次に、「入力ファイル名の入力」、「出力の入力」で前のステップで生成された test.exe ファイルを選択します。名前はデフォルトで構いません。
その後、下の [追加] ボタンをクリックして、nw.exe と test.nw と test.exe を除くすべてのファイルを追加します。 ファイルをロードし、[プロセス] をクリックして、実行が成功するまで待ちます。新しい .exe ファイルが対応するパスに生成されます (ここでは newtest.exe と呼びます)。この時点で、newtest.exe ファイルが Windows 環境で実行される場合は、それを友達にコピーして見せることができます。それ。
以下は、nw
1 の使用におけるいくつかの落とし穴です。ショートカット キーを実行する前に現在のアプリケーションにのみフォーカスを取得したい場合は、js を使用してショートカット キーを設定するこのライブラリを確認してください
// 加载本地ui库 var gui = require('nw.gui'); var option = { key: "Ctrl+R", active: function () { alert("全局快捷键" + this.key + "按下"); }, failed: function (msg) { //创建快捷键失败 alert(msg); } }; // 创建快捷键 var shortcut = new gui.Shortcut(option); // 注册全局快捷键 gui.App.registerGlobalHotKey(shortcut); // 解除注册,在应用结束的时候执行 gui.App.unregisterGlobalHotKey(shortcut);
。 2.nw.js ができない さまざまな異常によりページが複数回更新される これは、ページを更新した後に js ファイルを再読み込みし、変数を再割り当てすることによって発生するバグです。 解決策
nw.js はファイルを読み取って保存します
<html> <head> <meta charset="utf-8"/> <title>nw.js实现文件读写</title> </head> <body> <input id="readFile" type="file" >读取文件</input> <!-- 默认文件名为filename.html --> <input id="writeFile" nwsaveas="filename.html" type="file">保存文件</input> <p></p> <script> //nw.js提供的读写文件模块 var fs = require("fs"); //读文件 var chooser = document.querySelector('#readFile'); chooser.addEventListener("change", function (evt) { //用户选择的文件 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); } }) }); //写文件 chooser = document.querySelector('#writeFile'); chooser.addEventListener("change", function (evt) { //用户选择的文件 var filePath = this.value.toString(); document.querySelector("p").innerHTML = "写入文件到:" + filePath; //把hello写入文件 fs.writeFile(filePath, "Hello!\n", function (err) { if (err) { alert("保存失败!"); } }); }); </script> </body> </html>
3. nwjs の「fs」を使用して、cancas をローカル画像として直接保存します。インターネット上にある方法はすべて、保存するための選択ボックスを表示します。画像を指定されたパスに直接保存すると、ユーザーが選択できるダイアログ ボックスが表示されなくなります。 kailniris は、実行可能な解決策を提供しました。 コードは次のとおりです。
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 ページを画像に変換し、画像をローカルに保存します。コードを貼り付けます (html2canvas.js と jquery をインポートする必要があります):
//要保存图片的文件路径 var filePath = templateDir + filename + '.html'; //要保存的html页面 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 組み込みモジュールを参照します
//调用NodeJs内置模块 $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("读取微信配置文件失败"); } } //写入配置文件 $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("写入微信配置文件失败"); return false; } }
5. サードパーティ モジュール wechat-api を参照します
//调用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("查询菜单异常"); } else { load(result); $scope.$apply();//需要手动刷新 } }); };
上記は皆さんのためにまとめたものです。将来皆さんのお役に立てれば幸いです。
関連記事:
jQuery 同じイベントが迅速かつ繰り返しトリガーされるのを防ぐ方法
以上がNW.jsの基本的な使い方を詳しく紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。