Electron之自定義安裝路徑

關(guān)于 Electron

Electron是由Github開發(fā)巴碗,用HTML年栓,CSS和JavaScript來構(gòu)建跨平臺桌面應(yīng)用程序的一個開源庫。 Electron通過將Chromium和Node.js合并到同一個運行時環(huán)境中,并將其打包為Mac,Windows和Linux系統(tǒng)下的應(yīng)用來實現(xiàn)這一目的豺撑。

Electron打包工具

常用的打包工具有:electron-packager、electron-builder黔牵、grunt-electron-installer聪轿。

但是通過這些工具打包出來的APP,安裝的時候會安裝到默認(rèn)目錄下猾浦,不能指定安裝目錄陆错。對于Mac來說是很正常,但是對于Windows用戶來說就有點接受不了金赦。接下來我給大家介紹一下音瓷,針對Windows自定義安裝路徑的方法。

自定義安裝路徑

1.安裝asar

$?npm?install?asar

2.打包asar文件

$ asar pack 項目路徑 app.asar

然后你會發(fā)現(xiàn)在你的項目的同級目錄下多了一個app.asar文件素邪。

3.下載electron壓縮包

到官網(wǎng)下載electron的Windows版壓縮包外莲,然后解壓這個壓縮包,把a(bǔ)pp.asar文件放入解壓文件夾的resources目錄兔朦。

4.修改名稱和圖標(biāo)

找到解壓文件目錄下的electron.exe偷线,直接修改成你的應(yīng)用名稱。然后使用ResourceHacker軟件替換你成應(yīng)用圖標(biāo)沽甥,如下所示:

替換前
替換后

5.使用NSIS打包

下面是我寫的一個NSIS腳本声邦,你也可以替換其中的變量后直接使用:

; 安裝程序初始定義常量

!define PRODUCT_NAME "云報價"

!define PRODUCT_VERSION "2.0.0"

!define PRODUCT_PUBLISHER "劉武昌"

!define PRODUCT_WEB_SITE "http://www.reibang.com/u/1d53b932d536"

!define PRODUCT_UNINST_KEY "Software\Microsoft\Windows\CurrentVersion\Uninstall\${PRODUCT_NAME}"

!define PRODUCT_UNINST_ROOT_KEY "HKLM"

SetCompressor lzma

; ------ MUI 現(xiàn)代界面定義 (1.67 版本以上兼容) ------

!include "MUI.nsh"

; MUI 預(yù)定義常量

!define MUI_ABORTWARNING

!define MUI_ICON "E:\云報價\云報價\圖標(biāo)\icon_cloud_logo.ico"

!define MUI_UNICON "${NSISDIR}\Contrib\Graphics\Icons\modern-uninstall.ico"

; 歡迎頁面

!insertmacro MUI_PAGE_WELCOME

; 安裝目錄選擇頁面

!insertmacro MUI_PAGE_DIRECTORY

; 安裝過程頁面

!insertmacro MUI_PAGE_INSTFILES

; 安裝完成頁面

!insertmacro MUI_PAGE_FINISH

; 安裝卸載過程頁面

!insertmacro MUI_UNPAGE_INSTFILES

; 安裝界面包含的語言設(shè)置

!insertmacro MUI_LANGUAGE "SimpChinese"

; 安裝預(yù)釋放文件

!insertmacro MUI_RESERVEFILE_INSTALLOPTIONS

; ------ MUI 現(xiàn)代界面定義結(jié)束 ------

Name "${PRODUCT_NAME} ${PRODUCT_VERSION}"

OutFile "云報價.exe"

InstallDir "$PROGRAMFILES\云報價"

ShowInstDetails show

ShowUnInstDetails show

Section "MainSection" SEC01

? SetOutPath "$INSTDIR\*.*"

? SetOverwrite on

? File /r "..\云報價-window-32\*.*"

SectionEnd

Section -AdditionalIcons

? SetOutPath $INSTDIR

? WriteIniStr "$INSTDIR\${PRODUCT_NAME}.url" "InternetShortcut" "URL" "${PRODUCT_WEB_SITE}"

? CreateDirectory "$SMPROGRAMS\云報價"

? CreateShortCut "$SMPROGRAMS\云報價\Website.lnk" "$INSTDIR\${PRODUCT_NAME}.url"

? CreateShortCut "$SMPROGRAMS\云報價\Uninstall.lnk" "$INSTDIR\uninst.exe"

? CreateShortCut "$DESKTOP\${PRODUCT_NAME}.lnk" "$INSTDIR\云報價.exe"

SectionEnd

Section -Post

? WriteUninstaller "$INSTDIR\uninst.exe"

? WriteRegStr ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}" "DisplayName" "$(^Name)"

? WriteRegStr ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}" "UninstallString" "$INSTDIR\uninst.exe"

? WriteRegStr ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}" "DisplayVersion" "${PRODUCT_VERSION}"

? WriteRegStr ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}" "URLInfoAbout" "${PRODUCT_WEB_SITE}"

? WriteRegStr ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}" "Publisher" "${PRODUCT_PUBLISHER}"

SectionEnd

/******************************

*? 以下是安裝程序的卸載部分? *

******************************/

Section Uninstall

? Delete "$INSTDIR\${PRODUCT_NAME}.url"

? Delete "$INSTDIR\uninst.exe"

? Delete "$SMPROGRAMS\云報價\Uninstall.lnk"

? Delete "$SMPROGRAMS\云報價\Website.lnk"

? Delete "$DESKTOP\${PRODUCT_NAME}.lnk"

? RMDir "$SMPROGRAMS\云報價"

? RMDir /r "$INSTDIR\*.*"

? RMDir "$INSTDIR"

? DeleteRegKey ${PRODUCT_UNINST_ROOT_KEY} "${PRODUCT_UNINST_KEY}"

? SetAutoClose true

SectionEnd

#-- 根據(jù) NSIS 腳本編輯規(guī)則,所有 Function 區(qū)段必須放置在 Section 區(qū)段之后編寫摆舟,以避免安裝程序出現(xiàn)未可預(yù)知的問題亥曹。--#

Function un.onInit

? MessageBox MB_ICONQUESTION|MB_YESNO|MB_DEFBUTTON2 "您確實要完全移除 $(^Name) ,及其所有的組件恨诱?" IDYES +2

? Abort

FunctionEnd

Function un.onUninstSuccess

? HideWindow

? MessageBox MB_ICONINFORMATION|MB_OK "$(^Name) 已成功地從您的計算機(jī)移除媳瞪。"

FunctionEnd

6.效果演示

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市照宝,隨后出現(xiàn)的幾起案子蛇受,更是在濱河造成了極大的恐慌,老刑警劉巖厕鹃,帶你破解...
    沈念sama閱讀 211,496評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件兢仰,死亡現(xiàn)場離奇詭異乍丈,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)把将,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,187評論 3 385
  • 文/潘曉璐 我一進(jìn)店門轻专,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人察蹲,你說我怎么就攤上這事请垛。” “怎么了洽议?”我有些...
    開封第一講書人閱讀 157,091評論 0 348
  • 文/不壞的土叔 我叫張陵叼屠,是天一觀的道長。 經(jīng)常有香客問我绞铃,道長,這世上最難降的妖魔是什么嫂侍? 我笑而不...
    開封第一講書人閱讀 56,458評論 1 283
  • 正文 為了忘掉前任儿捧,我火速辦了婚禮,結(jié)果婚禮上挑宠,老公的妹妹穿的比我還像新娘菲盾。我一直安慰自己,他們只是感情好各淀,可當(dāng)我...
    茶點故事閱讀 65,542評論 6 385
  • 文/花漫 我一把揭開白布懒鉴。 她就那樣靜靜地躺著,像睡著了一般碎浇。 火紅的嫁衣襯著肌膚如雪临谱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,802評論 1 290
  • 那天奴璃,我揣著相機(jī)與錄音悉默,去河邊找鬼。 笑死苟穆,一個胖子當(dāng)著我的面吹牛抄课,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播雳旅,決...
    沈念sama閱讀 38,945評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼跟磨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了攒盈?” 一聲冷哼從身側(cè)響起抵拘,我...
    開封第一講書人閱讀 37,709評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎沦童,沒想到半個月后仑濒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體叹话,經(jīng)...
    沈念sama閱讀 44,158評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,502評論 2 327
  • 正文 我和宋清朗相戀三年墩瞳,在試婚紗的時候發(fā)現(xiàn)自己被綠了驼壶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,637評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡喉酌,死狀恐怖热凹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情泪电,我是刑警寧澤般妙,帶...
    沈念sama閱讀 34,300評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站相速,受9級特大地震影響碟渺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜突诬,卻給世界環(huán)境...
    茶點故事閱讀 39,911評論 3 313
  • 文/蒙蒙 一苫拍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧旺隙,春花似錦绒极、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,744評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至周拐,卻和暖如春铡俐,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背速妖。 一陣腳步聲響...
    開封第一講書人閱讀 31,982評論 1 266
  • 我被黑心中介騙來泰國打工高蜂, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人罕容。 一個月前我還...
    沈念sama閱讀 46,344評論 2 360
  • 正文 我出身青樓备恤,卻偏偏與公主長得像,于是被迫代替她去往敵國和親锦秒。 傳聞我的和親對象是個殘疾皇子露泊,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,500評論 2 348

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