ホームページ >ウェブフロントエンド >jsチュートリアル >NW.jsの基本的な使い方を詳しく紹介

NW.jsの基本的な使い方を詳しく紹介

亚连
亚连オリジナル
2018-06-08 15:05:2515059ブラウズ

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(&#39;#readFile&#39;);
 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(&#39;#writeFile&#39;);
 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(&#39;fs&#39;);
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, &#39;base64&#39;, function (err) {
 if (err) {
 console.log("err", err);
 } else {
 return res.json({ &#39;status&#39;: &#39;success&#39; });
 }
});

html2canvas を使用して HTML ページを画像に変換し、画像をローカルに保存します。コードを貼り付けます (html2canvas.js と jquery をインポートする必要があります):

//要保存图片的文件路径
  var filePath = templateDir + filename + &#39;.html&#39;;
  //要保存的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 + &#39;.png&#39;, base64Data, &#39;base64&#39;, function (err) {
   if (err) {
    alert("保存模板失败!");
   }
   $(&#39;#model_template_name&#39;).modal("hide");
   layer.msg("模板已保存为" + filename);
   });
  }
  });

4. app.js の Node 組み込みモジュールを参照します

//调用NodeJs内置模块
 $scope.fs = require(&#39;fs&#39;); 
     //读取配置文件
 $scope.readConfig = function () {
  try {
  var configStr = $scope.fs.readFileSync(config.weixin.path, &#39;utf8&#39;);
  console.log(configStr);
  var obj = eval(&#39;(&#39; + configStr + &#39;)&#39;);
  $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: &#39;utf8&#39;});
  return true;
  }
  catch (e) {
  console.log(e);
  alert("写入微信配置文件失败");
  return false;
  }
 }

5. サードパーティ モジュール wechat-api を参照します

//调用NodeJs第三方模块
 $scope.wechatApi = require(&#39;wechat-api&#39;);
 $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();//需要手动刷新
  }
  });
 };

上記は皆さんのためにまとめたものです。将来皆さんのお役に立てれば幸いです。

関連記事:

vux がプルアップリフレッシュ関数を実装する方法

jQuery による画像カルーセルの実装方法

jQuery 同じイベントが迅速かつ繰り返しトリガーされるのを防ぐ方法

以上がNW.jsの基本的な使い方を詳しく紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。