NW.js 簡介與使用

来源:https://www.cnblogs.com/yswenli/archive/2018/01/31/8393787.html
-Advertisement-
Play Games

簡介 (1)以網路最流行的技術編寫原生應用程式的新方法 (2)基於HTML5, CSS3, JS and WebGL而編寫 (3)完全支持nodejs所有api及第三方模塊 (4)可以使用DOM直接調用nodejs模塊 (5)容易打包和分發 (6)支持運行環境包括32位和64位的Window、Lin ...


簡介 (1)以網路最流行的技術編寫原生應用程式的新方法 (2)基於HTML5, CSS3, JS and WebGL而編寫 (3)完全支持nodejs所有api及第三方模塊 (4)可以使用DOM直接調用nodejs模塊 (5)容易打包和分發 (6)支持運行環境包括32位和64位的Window、Linux和Mac OS   使用方法如下:

一、下載nw

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

這裡面normal這個算是運行時吧,sdk那個是一些工具箱,建議都下下來~

https://nwjs.io/downloads/

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

二、配置 package.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 : 字元串,設置預設 title。
  • width/height : 主視窗的大小。
  • toolbar : bool 值。是否顯示導航欄。
  • icon : 視窗的 icon。
  • position :字元串。視窗打開時的位置,可以設置為“null”、“center”或者“mouse”。
  • min_width/min_height : 視窗的最小值。
  • max_width/max_height : 視窗顯示的最大值。
  • resizable : bool 值。是否允許調整視窗大小。
  • always-on-top : bool 值。視窗置頂。
  • fullscreen : bool 值。是否全屏顯示。
  • show_in_taskbar : 是否在任務欄顯示圖標。
  • frame : bool 值。如果設置為 false,程式將無邊框顯示。
  • "chromium-args" :"-allow-file-access-from-files" 相當於給谷歌瀏覽器添加啟動參數一樣,這行代碼允許angularjs直接訪問本地json文件。

三、生成exe

項目目錄如下:

 

將html項目壓縮成zip,並改名為nw,輸入以下命令

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

四、打發包發佈

打開 Enigma Virtual Box 程式(enigmavb.exe),界面應該是這樣的:

然後在 Enter Input File Name 處選擇上一步生成的 test.exe 文件,Enter Output Name 可以預設;

之後再點擊下麵的 Add 按鈕,將 nwjs 文件夾(名稱不一定是 nwjs ,就是最開始第一步 NW.js 環境的那個文件夾)下除 nw.exe 和 test.nw 以及 test.exe 之外的所有文件載入上,然後點擊 Process ,等待執行成功即可,這時候會在相應的路徑下生成一個新的 .exe 文件(我們暫且叫做 newtest.exe),此時的 newtest.exe 文件即可在任意的 Windows 環境下運行了,你可以拷貝給你的小伙伴去 Show 一下。

下麵是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文件對變數重新賦值引起的bug。 解決方案

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();//需要手動刷新
                }
            });
        };

 

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • github項目代碼地址,歡迎start https://github.com/979451341/EventLine 接著上一篇繼續寫,這次我們要在接收函數上使用元註解來區別接收函數需要在哪個線程執行 然後在EventLine裡面添加兩個常量 使用元註解 實現我們需要得到activity的rece ...
  • 引言,有一天我在調試一個界面,xml佈局裡面包含Scroll View,裡面嵌套了recyclerView的時候,界面一進去,就自動滾動到了recyclerView的那部分,百思不得其解,上網查了好多資料,大部分只是提到瞭解決的辦法,但是對於為什麼會這樣,都沒有一個很好的解釋,本著對技術的負責的態度 ...
  • 在移動端開打過程中,經常會用到通知和推送,例如有簡訊來了需要通知提示,手機橫屏了需要通知提示,插上耳機了需要通知提示等等,我們可以根據這些通知採取對應的動作。iOS系統自身定義了很對通知,但是在開發過程中我們也可以進行自定義一些通知,然後利用NSNotificationCenter在需要的時候進行發 ...
  • 我新建了一個web前端的新手交流群,包括基礎知識和剛入職的技術分享,人還不多,期待著每一個人的加入,希望可以得到你的認同哦~你的加入是我組織交流群的一大動力哦!~ 歡迎大佬進駐,有很多萌新等待大佬的幫助哦! web前端交流QQ群:314439765 ...
  • 在使用JavaScript開發大型項目時,模塊開發概念是一個必須考慮的問題。其目的就是通過命名空間對各類業務對象進行一定的封裝,防止命名衝突。 本篇著重介紹ES6 module中的export和import概念。 ...
  • 效果: 代碼: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Title</title> 6 <script src="http://www.51rgb.com/js/jquery.js ...
  • 效果: 代碼: 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>Title</title> 6 <style> 7 *{padding: 0px;margin: 0px;} 8 li{ 9 ...
  • javascript 基礎知識 一.javascript的特點 瀏覽器腳本語言,可以跟html代碼進行混排 跨平臺性能優越,可以再windows.linux上進行編寫 安全性好 相容性好 二.javascrpt 有三大學習目標 特效 表單驗證 ajax 三.javascript 基礎語法 javas ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...