NodeJS, Electron 構(gòu)建你的桌面程序

  1. 安裝electron, electron-prebuilt
$ npm install cnpm -g --registry=http://registry.npm.taobao.org
$ cnpm install electron -g
$ cnpm install electron-prebuilt -g
  1. 安裝electron-packager, electron-builder, asar
$ cnpm install electron-packager -g
$ cnpm install electron-builder -g
$ cnpm install asar -g
  1. 初始化項(xiàng)目
$ cnpm init

執(zhí)行完后, 當(dāng)前目錄下生成package.json文件

{
  "name": "own-runner",
  "version": "1.0.0",
  "description": "神器",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "PeopleName",
  "license": "ISC"
}
  1. 添加index.html, index.js

index.html

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="UTF-8"/>
    <title>test</title>
</head>
<body>
    Hello World!

    <button id="button">點(diǎn)擊這里</button>

<script>
    console.log(window)

    var button = document.getElementById('button');

    button.onclick = function(){
            alert("Hello Electron!")
    }

</script>
</body>
</html>

index.js

const {app, BrowserWindow} = require('electron')
const path = require('path')
const url = require('url')

// 保存窗口對(duì)象的全局引用, 如果不這樣做, 當(dāng)JavaScript對(duì)象被當(dāng)做垃圾回收時(shí)届搁,window窗口會(huì)自動(dòng)關(guān)閉
let win

function createWindow () {
  // 創(chuàng)建瀏覽器窗口.
  win = new BrowserWindow({width: 800, height: 600,autoHideMenuBar :true})

  win.setMenu(null);

  // 加載項(xiàng)目的index.html文件.
  win.loadURL(url.format({
    pathname: path.join(__dirname, 'index.html'),
    protocol: 'file:',
  // 當(dāng)窗口關(guān)閉時(shí)候的事件.
    slashes: true
  }))

  // 打開開發(fā)工具.
  //win.webContents.openDevTools()

  win.on('closed', () => {
    // 取消引用窗口對(duì)象, 如果你的應(yīng)用程序支持多窗口贮配,通常你會(huì)儲(chǔ)存windows在數(shù)組中躬贡,這是刪除相應(yīng)元素的時(shí)候。
    console.log("haha");

    win = null
  })
}

app.on('activate', () => {
  console.log('activate')
  if (win === null) {
    createWindow()
  } else {
    win.show()
  }
})

// 當(dāng)Electron完成初始化并準(zhǔn)備創(chuàng)建瀏覽器窗口時(shí)莺掠,將調(diào)用此方法
// 一些api只能在此事件發(fā)生后使用。
app.on('ready', createWindow)

// 當(dāng)所有窗口關(guān)閉時(shí)退出隅很。
app.on('window-all-closed', () => {
  // 在macOS上,用得多的是應(yīng)用程序和它們的菜單欄升筏,用Cmd + Q退出。
  if (process.platform !== 'darwin') {
    app.quit()
  }
})

app.on('activate', () => {
  // 在macOS上瘸爽,當(dāng)點(diǎn)擊dock圖標(biāo)并且沒有其他窗口打開時(shí),通常會(huì)在應(yīng)用程序中重新創(chuàng)建一個(gè)窗口铅忿。
  if (win === null) {
    createWindow()
  }
})
  1. 修改package.json
"scripts": {
    "start": "electron .",
    "pack": "electron-builder --dir",
    "dist": "electron-builder"
},
"build": {
    "appId": "隨意",
    "win": {
        
    }
},
  1. 打包或運(yùn)行
$ npm|cnpm|yarn install
$ npm|cnpm|yarn dist #dist目錄下生成exe文件
$ npm|cnpm|yarn start #運(yùn)行 

Ref.

Electron: https://electronjs.org/docs

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末剪决,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子檀训,更是在濱河造成了極大的恐慌柑潦,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件峻凫,死亡現(xiàn)場離奇詭異渗鬼,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)荧琼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門譬胎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人命锄,你說我怎么就攤上這事堰乔。” “怎么了脐恩?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵镐侯,是天一觀的道長。 經(jīng)常有香客問我驶冒,道長苟翻,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任骗污,我火速辦了婚禮,結(jié)果婚禮上身堡,老公的妹妹穿的比我還像新娘。我一直安慰自己贴谎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布擅这。 她就那樣靜靜地躺著澈魄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪仲翎。 梳的紋絲不亂的頭發(fā)上铛漓,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天鲫构,我揣著相機(jī)與錄音浓恶,去河邊找鬼。 笑死结笨,一個(gè)胖子當(dāng)著我的面吹牛包晰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播炕吸,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼树肃!你這毒婦竟也來了瀑罗?” 一聲冷哼從身側(cè)響起胸嘴,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤筛谚,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后停忿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吮铭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年颅停,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片癞揉。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖柏肪,靈堂內(nèi)的尸體忽然破棺而出芥牌,到底是詐尸還是另有隱情烦味,我是刑警寧澤壁拉,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布柏靶,位于F島的核電站溃论,受9級(jí)特大地震影響屎蜓,放射性物質(zhì)發(fā)生泄漏蔬芥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一笔诵、第九天 我趴在偏房一處隱蔽的房頂上張望姑子。 院中可真熱鬧,春花似錦街佑、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽褒侧。三九已至谊迄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間统诺,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來泰國打工婿失, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人豪硅。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓这难,卻偏偏與公主長得像,于是被迫代替她去往敵國和親姻乓。 傳聞我的和親對(duì)象是個(gè)殘疾皇子眯牧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容