溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用JavaScript開發(fā)跨平臺的桌面應用

發(fā)布時間:2021-08-09 14:18:37 來源:億速云 閱讀:135 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關如何使用JavaScript開發(fā)跨平臺的桌面應用的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

任何可以使用JavaScript來編寫的應用,最終會由JavaScript編寫。--Atwood定律

Atwood's Law是Jeff Atwood在2007年提出的:“any application that can be written in JavaScript, will eventually be written in JavaScript.”。據(jù)說,這只是當時開的一個玩笑。不過,這個玩笑似乎漸漸變成了現(xiàn)實。從各種華麗的網(wǎng)頁框架,到功能強大的庫,到了現(xiàn)在的機器學習,服務器開發(fā),都有JavaScript的身影。從JavaScript也衍生出了一些語言,例如TypeScript。而使用JavaScript制作游戲也變得方便起來,可以使用CocosCreator。Html5的橫空出世,也將之前JavaScript在網(wǎng)頁的輔助地位提升到了主力地位,nodejs的出現(xiàn)更是讓其實現(xiàn)了所謂的“全棧”開發(fā),現(xiàn)在JavaScript甚至可以做手機應用。但是,在移動端、瀏覽器、服務器端有需求,在桌面應用上也會有需求。能不能使用JavaScript來開發(fā)可以跨平臺的應用程序呢?答案是:可以。使用Electron即可方便的使用JavaScript進行桌面應用開發(fā)??梢钥吹剑芏啻竺ΧΦ某绦蚨际怯伤苯踊蜷g接開發(fā)而成,例如Atom,VSCode等。

需要注意的是,目前使用Electron開發(fā)桌面應用程序有一些限制條件。首先,我們無法調(diào)用復雜的系統(tǒng)API(或者說不能直接做到),這就導致我們無法開發(fā)更加復雜的企業(yè)級應用。其次,它的性能目前仍然不能與原生應用相提并論。我們可以認為,Electron就是一個套著瀏覽器外殼的包裝盒,這個包裝盒給我們讀寫文件的能力,我們開發(fā)好web應用程序,調(diào)試完成后使用它來進行封裝,給我們的web應用程序加一個瀏覽器內(nèi)核。這樣,我們的js代碼就可以脫離傳統(tǒng)瀏覽器模式,獨立運行了。然而它和傳統(tǒng)的瀏覽器模式道理是一樣的,所以有極高性能需求時,還是需要使用C++、Java等開發(fā)。但大多數(shù)的應用程序根本不需要那么高的性能要求,所以使用Electron開發(fā)是沒有問題的。接下來,我們嘗試著從零開始,一步一步的使用Electron來開發(fā)Windows桌面應用,當然Mac和Linux也適用此方法。

首先,我們進入Electron的官網(wǎng):https://electron.atom.io/。進入后,發(fā)現(xiàn)全英文,不要緊,實際上大多數(shù)都可以不看。我們直接來到首頁的這里:

如何使用JavaScript開發(fā)跨平臺的桌面應用

如圖所示,官方給出的安裝方法是使用git和npm,但我們可以不使用git。然而,npm是必要的。npm是nodejs的包管理工具,新版本的nodejs已經(jīng)集成了npm,安裝nodejs后直接附帶npm。然而,一些舊版本的nodejs,或者從一些非官方處下載的不可靠的nodejs,可能不帶npm,所以我們在使用它之前必須先安裝nodejs和npm。網(wǎng)上有很多教程,這里不再演示。需要注意的是,第三個命令npm install && npm start中,我們可以只輸入npm install,因為后面附帶的指令很可能導致控制臺“死機”的情況,一直卡住且無法成功安裝Electron。所以,我們只要進入我們指定的目錄,然后執(zhí)行以下命令即可(這些命令各個系統(tǒng)通用):

如何使用JavaScript開發(fā)跨平臺的桌面應用

如何使用JavaScript開發(fā)跨平臺的桌面應用

如此一來,我們就安裝好了Electron。文件夾中:

如何使用JavaScript開發(fā)跨平臺的桌面應用

打開來看,文件的目錄結構是這樣的:

如何使用JavaScript開發(fā)跨平臺的桌面應用

目錄看似復雜,其實,我們甚至可以不管這些文件!main.js可以相當于我們的配置文件,里面有一些配置信息,默認情況下,我們的應用程序會直接打開這個目錄下的index.html。我們可以通過修改main.js中的參數(shù)來更改入口文件。當然,package.json也有用,之后都會講到。

首先,我們可以使用electron.exe直接運行應用。在我的目錄中,electron.exe在E:\electron-quick-start\node_modules\electron\dist目錄下。我們可以使用electron.exe <rootpath> 這種命令格式直接運行我們的應用,rootpath代表你要運行的項目目錄。例如,我之前用three.js編寫的應用,目錄是:E:\app。

如何使用JavaScript開發(fā)跨平臺的桌面應用

我們在控制臺中輸入指令:如何使用JavaScript開發(fā)跨平臺的桌面應用

效果:

如何使用JavaScript開發(fā)跨平臺的桌面應用

確實是以桌面應用程序的形式運行了。但是,我們希望我們的應用程序直接打包成.exe,.app的形式,而不是讓我們的用戶手動輸入命令啟動應用程序。而看看官方文檔,你就會發(fā)現(xiàn),官方給出的打包方法還是有一些坑的,如果處理不好,就要中招。所以,我們使用更加方便的electron-packager。github鏈接在此:https://github.com/electron-userland/electron-packager。首先,我們還是按教程輸入指令來安裝它。同樣,這個指令在Linux,Mac,Windows上通用。

如何使用JavaScript開發(fā)跨平臺的桌面應用

安裝方法和Electron一樣,從git上下載下來,進行安裝。需要注意的是,上圖的兩個指令我們執(zhí)行其中一個就可以了。推薦執(zhí)行第二個,因為第二個是全局安裝,安裝之后我們就可以在控制臺直接執(zhí)行electron-packager命令,大大方便了我們的效率。

安裝好后,我們開始打包。首先,把我們的項目目錄拷貝到我們之前安裝的electron目錄下:

如何使用JavaScript開發(fā)跨平臺的桌面應用

由于我們的應用程序入口文件是app下的CG1.html,所以我們還需要打開main.js配置一下入口文件:

如何使用JavaScript開發(fā)跨平臺的桌面應用

然后,打開package.json文件,配置一下參數(shù)。

如何使用JavaScript開發(fā)跨平臺的桌面應用

這里只配置了name參數(shù),因為name參數(shù)和我們打包之后生成的應用程序名稱有關。接下來,通過控制臺進入我們的electron目錄(就是有main.js有package.json的那個目錄),

在控制臺執(zhí)行如下命令:

如何使用JavaScript開發(fā)跨平臺的桌面應用

不要漏看了還有個".",這個指當前目錄的意思。其實,如果全局安裝了electron-packager,那我們呀可以把.換成任意的路徑。由于這個命令可以自動的檢測當前計算機的操作系統(tǒng),還能檢測出是32位還是64位,所以我們大可省略一些參數(shù)。但如果要生成可定制平臺的軟件,需要帶上一些參數(shù),詳細的在其項目的github中都已給出。相信大家如果有這個需求,那搞定這些參數(shù)應該不在話下。靜待一會兒,打包完畢。我們可以在文件夾下看到多了一個名為CG1-win32-x64的文件夾。打開之后,點擊CG1.exe,即可打開應用程序,此程序已經(jīng)可以作為發(fā)布版本提供給用戶!

如何使用JavaScript開發(fā)跨平臺的桌面應用

感謝各位的閱讀!關于“如何使用JavaScript開發(fā)跨平臺的桌面應用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI