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