利用Node.js編寫跨平臺的spawn語句詳解
前言
Node.js 是跨平臺的,也就是說它能運行在 Windows、OSX 和 Linux 平臺上。很多 Node.js 開發(fā)者都是在 OSX 上做開發(fā)的,然后再將代碼部署到 Linux 服務(wù)器上。由于 OSX 和 Linux 都是基于 Unix 的,因此兩者共性很多。Windows 也是 Node.js 官方支持的平臺,只要你通過正確的方式寫代碼,就能在各個平臺上毫無壓力的跑起來。
Node.js 的子進程 (child_process
) 模塊下有一 spawn
函數(shù),可以用于調(diào)用系統(tǒng)上的命令,如在 Linux, macOS 等系統(tǒng)上,我們可以執(zhí)行
const spawn = require('child_process').spawn; spawn('npm', { stdio: 'inherit' });
來調(diào)用 npm
命令。
然而,同樣的語句在 Windows 上執(zhí)行則會報錯。
Error: spawn npm ENOENT at exports._errnoException (util.js:855:11) at Process.ChildProcess._handle.onexit (internal/child_process.js:178:32) at onErrorNT (internal/child_process.js:344:16) at nextTickCallbackWith2Args (node.js:455:9) at process._tickCallback (node.js:369:17) at Function.Module.runMain (module.js:432:11) at startup (node.js:141:18) at node.js:980:3
因為在 Windows 上,當(dāng)我們執(zhí)行 npm 時,我們實際執(zhí)行的是 npm.cmd
批處理,而在 Windows 上, .cmd
, .bat
批處理是無法脫離 cmd.exe
這一解釋器而單獨運行的。
因此,我們需要顯式地調(diào)用 cmd
spawn('cmd', ['/c', 'npm'], { stdio: 'inherit' });
或者使用在調(diào)用 spawn
函數(shù)時,設(shè)置 shell
選項為 true
以隱式地調(diào)用 cmd
(該選項添加自 Node.js v6 版本)
spawn('npm', { stdio: 'inherit', shell: true });
另外,雖然在 Linux, macOS 等系統(tǒng)上不需要設(shè)置 shell
選項,命令也能夠正常執(zhí)行;設(shè)置 shell
為 true
也不會妨礙命令的執(zhí)行,只是會額外的產(chǎn)生一個本不必要的 shell 進程,影響性能。
因此,如果想要編寫跨平臺的 spawn
命令,而又不想增加額外的開銷的話,可以這樣寫
const process = require('process'); const { spawn } = require('child_process'); spawn('npm', { stdio: 'inherit', // 僅在當(dāng)前運行環(huán)境為 Windows 時,才使用 shell shell: process.platform === 'win32' });
第三方模塊 cross-spawn
關(guān)于 spawn
函數(shù)的跨平臺寫法,除了自己編寫代碼的時候做處理,也有第三方模塊封裝好了相關(guān)細節(jié),如 cross-spawn。
使用該模塊,可以在調(diào)用 spawn
函數(shù)時,自動根據(jù)當(dāng)前的運行平臺,來決定是否生成一個 shell
來執(zhí)行所給的命令。
而且,還能夠
- 支持低于 v6 的 Node.js 版本 (使用
shell
選項需要至少 Node.js v6); - 跨平臺地支持 shebang;
- 對命令和參數(shù)中的字符進行轉(zhuǎn)義更為方便。
安裝
npm install cross-spawn
用法
const spawn = require('cross-spawn'); spawn('npm', { stdio: 'inherit' });
參考文檔
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
nodejs實現(xiàn)的http、https 請求封裝操作示例
這篇文章主要介紹了nodejs實現(xiàn)的http、https 請求封裝操作,結(jié)合實例形式分析了node.js針對http、https 請求的封裝與使用相關(guān)操作技巧,需要的朋友可以參考下2020-02-02Node.JS用純JavaScript生成圖片或滑塊式驗證碼功能
有一些Node.JS圖片生成類庫,比如node-captcha等的類庫,需要c/c++程序生成圖片。跨平臺部署不是很方便。這里介紹幾個用純JS實現(xiàn)的圖片驗證碼生成模塊,需要的朋友可以參考下2019-09-09node.js使用Moment.js js 時間計算方法示例小結(jié)
這篇文章主要介紹了node.js使用Moment.js js 時間計算方法,結(jié)合實例形式分析了Moment.js js模塊時間計算的常用操作技巧與相關(guān)注意事項,需要的朋友可以參考下2023-05-05node.js通過axios實現(xiàn)網(wǎng)絡(luò)請求的方法
下面小編就為大家分享一篇node.js通過axios實現(xiàn)網(wǎng)絡(luò)請求的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03node+koa+canvas繪制出貨單、收據(jù)票據(jù)的方法
在生成票據(jù)需求中,我們會想到前端生成或者后端生成返回圖片地址訪問兩個方法,前端生成則不需要調(diào)用接口,而后端是在完成整個流程時就進行生成然后把上傳的地址保存數(shù)據(jù)庫,這篇文章主要介紹了node+koa+canvas繪制出貨單,收據(jù),票據(jù),需要的朋友可以參考下2022-09-09node實現(xiàn)生成帶參數(shù)的小程序二維碼并保存到本地功能示例
這篇文章主要介紹了node實現(xiàn)生成帶參數(shù)的小程序二維碼并保存到本地功能,涉及nodejs模塊引用、接口調(diào)用、編碼轉(zhuǎn)換、圖片生成等相關(guān)操作技巧,需要的朋友可以參考下2018-12-12