>  기사  >  웹 프론트엔드  >  NW.js의 기본 사용법에 대한 자세한 소개

NW.js의 기본 사용법에 대한 자세한 소개

亚连
亚连원래의
2018-06-08 15:05:2514971검색

NW.js(이전의 node-webkit)는 Chromium과 node.js를 기반으로 하는 애플리케이션 런타임으로 이를 통해 HTML 및 JavaScript로 기본 애플리케이션을 작성할 수 있습니다. 이 기사에서는 주로 NW.js의 소개와 사용 방법을 소개합니다. 친구는

Introduction

NW.js(이전의 node-webkit)를 참조할 수 있습니다. NW.js(이전의 node-webkit)는 Chromium 및 node.js 기반의 애플리케이션 런타임으로, 이를 통해 기본 애플리케이션을 HTML 및 JavaScript로 작성할 수 있습니다. . 또한 DOM에서 Node.js 모듈을 호출할 수 있으므로 모든 웹 기술을 사용하여 기본 애플리케이션을 작성하기 위한 새로운 개발 모델이 가능해집니다.

(1) 인터넷에서 가장 널리 사용되는 기술로 기본 애플리케이션을 작성하는 새로운 방법

(2) HTML5, CSS3, JS 및 WebGL을 기반으로 작성됨

(3) 모든 nodejs API 및 타사 모듈을 완벽하게 지원

( 4) DOM을 사용하여 nodejs 모듈을 직접 호출할 수 있습니다.

(5) 패키징 및 배포가 용이합니다.

(6) 32비트 및 64비트 Window, Linux 및 Mac OS를 포함한 운영 환경 지원

The 사용 방법은 다음과 같습니다.

一, nw

1. NW.js 다운로드(공식 홈페이지: http://nwjs.io/)

일반적인 것으로 간주됩니다. SDK는 일부 도구 상자이므로 모두 다운로드하는 것이 좋습니다~

https://nwjs.io/downloads/

2. Enigma Virtual Box 다운로드(공식 웹사이트: 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: 문자열, 기본 제목을 설정합니다.

  • 너비/높이 : 메인 창의 크기입니다.

  • toolbar : 부울 값. 탐색 표시줄을 표시할지 여부입니다.

  • icon: 창의 아이콘입니다.

  • 위치 : 문자열. 창이 열릴 때의 위치는 "null", "center", "mouse"로 설정할 수 있습니다.

  • min_width/min_height: 창의 최소값.

  • max_width/max_height: 창에 표시되는 최대값입니다.

  • 크기 조정 가능: 부울 값. 창 크기 조정을 허용할지 여부입니다.

  • always-on-top : 부울 값. 상단에 창입니다.

  • 전체 화면: 부울 값. 전체 화면으로 표시할지 여부입니다.

  • show_in_taskbar: 작업 표시줄에 아이콘을 표시할지 여부입니다.

  • frame : 부울 값. false로 설정하면 프로그램이 테두리 없이 표시됩니다.

  • "chromium-args" :"-allow-file-access-from-files"는 Google Chrome에 시작 매개변수를 추가하는 것과 동일합니다. 이 코드 줄을 사용하면 Anglejs가 로컬 json 파일에 직접 액세스할 수 있습니다.

3. exe

생성 프로젝트 디렉토리는 다음과 같습니다.

html 프로젝트를 zip으로 압축하고 이름을 nw로 바꾸고 다음 명령을 입력합니다

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

4. the package

Enigma Virtual Box 프로그램(enigmavb.exe)을 엽니다. 인터페이스는 다음과 같아야 합니다.

그런 다음 입력 파일 이름 입력, 출력 입력의 이전 단계에서 생성된 test.exe 파일을 선택합니다. 이름은 기본값일 수 있습니다.

After 그런 다음 아래 추가 버튼을 클릭하고 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가 안되는데 여러가지 이상으로 페이지가 여러번 새로고침되는 현상입니다. 해결 방법

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. cancas를 로컬 이미지로 직접 저장하려면 nwjs의 'fs'를 사용하세요. 인터넷에서 찾은 방법은 모두 선택 상자가 뜨는데 저장해야 합니다. 이미지를 지정된 경로에 직접 추가하는 경우 사용자가 선택할 수 있는 대화 상자가 나타날 수 없습니다. 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

//调用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에서 Node 내장 모듈을 참조하세요. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.