掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
本文轉(zhuǎn)載自微信公眾號(hào)「JS每日一題」,作者灰灰。轉(zhuǎn)載本文請(qǐng)聯(lián)系JS每日一題公眾號(hào)。

成都創(chuàng)新互聯(lián)是專業(yè)的達(dá)州網(wǎng)站建設(shè)公司,達(dá)州接單;提供成都做網(wǎng)站、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行達(dá)州網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
process 對(duì)象是一個(gè)全局變量,提供了有關(guān)當(dāng)前 Node.js進(jìn)程的信息并對(duì)其進(jìn)行控制,作為一個(gè)全局變量
我們都知道,進(jìn)程計(jì)算機(jī)系統(tǒng)進(jìn)行資源分配和調(diào)度的基本單位,是操作系統(tǒng)結(jié)構(gòu)的基礎(chǔ),是線程的容器
當(dāng)我們啟動(dòng)一個(gè)js文件,實(shí)際就是開啟了一個(gè)服務(wù)進(jìn)程,每個(gè)進(jìn)程都擁有自己的獨(dú)立空間地址、數(shù)據(jù)棧,像另一個(gè)進(jìn)程無法訪問當(dāng)前進(jìn)程的變量、數(shù)據(jù)結(jié)構(gòu),只有數(shù)據(jù)通信后,進(jìn)程之間才可以數(shù)據(jù)共享
由于JavaScript是一個(gè)單線程語言,所以通過node xxx啟動(dòng)一個(gè)文件后,只有一條主線程
關(guān)于process常見的屬性有如下:
下面再稍微介紹下某些方法的使用:
返回當(dāng)前 Node進(jìn)程執(zhí)行的目錄
一個(gè)Node 模塊 A 通過 NPM 發(fā)布,項(xiàng)目 B 中使用了模塊 A。在 A 中需要操作 B 項(xiàng)目下的文件時(shí),就可以用 process.cwd() 來獲取 B 項(xiàng)目的路徑
在終端通過 Node 執(zhí)行命令的時(shí)候,通過 process.argv 可以獲取傳入的命令行參數(shù),返回值是一個(gè)數(shù)組:
0: Node 路徑(一般用不到,直接忽略)
1: 被執(zhí)行的 JS 文件路徑(一般用不到,直接忽略)
2~n: 真實(shí)傳入命令的參數(shù)
所以,我們只要從 process.argv[2] 開始獲取就好了
- const args = process.argv.slice(2);
返回一個(gè)對(duì)象,存儲(chǔ)當(dāng)前環(huán)境相關(guān)的所有信息,一般很少直接用到。
一般我們會(huì)在 process.env 上掛載一些變量標(biāo)識(shí)當(dāng)前的環(huán)境。比如最常見的用 process.env.NODE_ENV 區(qū)分 development 和 production
在 vue-cli 的源碼中也經(jīng)常會(huì)看到 process.env.VUE_CLI_DEBUG 標(biāo)識(shí)當(dāng)前是不是 DEBUG 模式
我們知道NodeJs是基于事件輪詢,在這個(gè)過程中,同一時(shí)間只會(huì)處理一件事情
在這種處理模式下,process.nextTick()就是定義出一個(gè)動(dòng)作,并且讓這個(gè)動(dòng)作在下一個(gè)事件輪詢的時(shí)間點(diǎn)上執(zhí)行
例如下面例子將一個(gè)foo函數(shù)在下一個(gè)時(shí)間點(diǎn)調(diào)用
- function foo() {
- console.error('foo');
- }
- process.nextTick(foo);
- console.error('bar');
輸出結(jié)果為bar、foo
雖然下述方式也能實(shí)現(xiàn)同樣效果:
- setTimeout(foo, 0);
- console.log('bar');
兩者區(qū)別在于:
參考文獻(xiàn)
http://nodejs.cn/api/process.html
https://vue3js.cn/interview/

我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流