成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

nodejs模塊整理

王笑朝 / 1208人閱讀

摘要:本篇將對規(guī)范,的文件模塊和核心模塊等做一個(gè)綜合的整理。其他后綴名的文件,都會(huì)被當(dāng)成是文件進(jìn)行處理。總結(jié)至此我們對的模塊整體的機(jī)制,大致已經(jīng)整理清楚了,從模塊的導(dǎo)出,到引入,以及標(biāo)識(shí)符的分析。

前言

模塊對于node來說是不可或缺的一部分,是服務(wù)端編程的基礎(chǔ)。趁著整理模塊之際,先將node部分的模塊的封裝等做一個(gè)總結(jié)。希望能夠切實(shí)的幫助到你。本篇將對CommenJS規(guī)范,node的文件模塊和核心模塊等做一個(gè)綜合的整理。如果你喜歡我的文章,歡迎評論,歡迎Star~。歡迎關(guān)注我的github博客

正文

我覺得模塊的出現(xiàn)是js進(jìn)步最大的地方。因?yàn)橛辛四K,才使得很多優(yōu)秀的東西可以真正被共享出來,而不用去擔(dān)心變量污染、命名空間的問題。

node作為一門服務(wù)端的javascript,它借鑒了CommonJS的規(guī)范,形成了一套易用的模塊規(guī)范。

首先,看看下面這個(gè)最常見的例子:

//circle.js

const { PI } = Math;

exports.area = x => PI*x**2;
exports.circle = x => 2*PI*x;
//main.js

const circle = require("./circle");

console.log(circle.area(4));   //50.26548245743669

其實(shí),我們可以清晰地看到兩個(gè)文件中,模塊規(guī)范部分可以分成三部分:

require(模塊引用) => 這是整個(gè)模塊系統(tǒng)最核心的部分,能夠引入其他模塊,充分的運(yùn)用。

exports(模塊定義) => 另一個(gè)出彩的地方,可以將自身模塊中的內(nèi)容導(dǎo)出,供其他模塊使用。

標(biāo)識(shí)(模塊標(biāo)識(shí)) => 供別人認(rèn)清楚模塊的東西。

這三塊內(nèi)容可以使用一張圖片概括:

如圖:

從這幅圖中,我們可以看到,模塊之間可以通過exports將接口暴露出來,然后通過require來對另一個(gè)模塊內(nèi)的內(nèi)容進(jìn)行引入。

這樣我們就大概懂得了模塊的定義。它主要分為三部分:模塊的引用、模塊定義和模塊標(biāo)識(shí)。

然而,整個(gè)模塊部分我們最需要去了解的是require機(jī)制。node對于require實(shí)現(xiàn),有很多的東西可以去欣賞。

首先,需要明白的是整個(gè)模塊引入的步驟。從上面的例子中,可以看出這三部分:

路徑分析 => 拿例子來進(jìn)行分析的話,"./circle"就是路徑。(./此類的是相對路徑,當(dāng)然還有絕對路徑)

文件定位 => 通過分析出來的位置,去進(jìn)行文件的獲取。

編譯執(zhí)行 => 只有通過編譯過的文件,才能夠放入其他模塊中進(jìn)行使用 (之后也會(huì)分析如何進(jìn)行編譯的)。

有的時(shí)候,情況是特殊的。模塊本身就分成核心模塊和文件模塊。而核心模塊在node源代碼編譯的時(shí)候。就被編譯成二進(jìn)制文件。并且部分核心模塊會(huì)在node進(jìn)程啟動(dòng)時(shí),直接加載到內(nèi)存中,因此這一部分的核心模塊引入是不需要經(jīng)過文件定位和編譯執(zhí)行的步驟的。

還有特殊就是在緩存部分。每個(gè)模塊首次加載之后,node會(huì)緩存其編譯執(zhí)行后的對象,方便二次加載。所以,二次加載時(shí),是以緩存優(yōu)先的,從緩存中加載的模塊也是不需要文件定位和編譯的。

單從路徑分析說起,可以分成三種不同的方式:

核心模塊,如http、fs、path等,加載優(yōu)先級(jí)僅次于緩存加載,且會(huì)直接編譯成二進(jìn)制文件

路徑形式的模塊,如上面例子中的‘./circle’。路徑明確,查找速度相對較快,加載速度慢于核心模塊

自定義模塊,大多如npm包形式的文件,存儲(chǔ)在node_modules,并沒有相應(yīng)的路徑。這種查找比較繁瑣。

查找方式: 1. 從當(dāng)前目錄下面的node_modules中查找是否具備相應(yīng)的模塊 2. 若具備,則直接加載使用,否則,會(huì)去查找父目錄下的node_modules目錄,直至查找到根目錄下的node_modules中。這種方式是最慢的。

再來分析文件定位:

第一個(gè)例子中的標(biāo)識(shí)符是"./circle"??梢园l(fā)現(xiàn),這個(gè)文件標(biāo)識(shí)符是沒有后綴名的。那么,node是如何來進(jìn)行定位的呢?其實(shí),node有一個(gè)默認(rèn)的定位順序:js、node、json。這里會(huì)最先識(shí)別js,之后一次對json和node的文件進(jìn)行識(shí)別。因此,這里有個(gè)小技巧:在識(shí)別.node和.json的文件的時(shí)候,帶上文件后綴名會(huì)快一點(diǎn), 為什么呢?是因?yàn)?,node是使用fs同步阻塞的方式,逐一去嘗試,該文件是否存在,存在著直接加載;不存在的話,嘗試下一個(gè)后綴名。

還有對于那些自定義的模塊,如npm包。node的定位方式也是不同的。通常來說,npm包中都會(huì)具備package.json文件,這個(gè)文件中有個(gè)main屬性,這指向的就是整個(gè)包的入口文件;如果沒有這些條件,node會(huì)去默認(rèn)加載index.js、index.json和index.node

最后就是模塊編譯部分的分析了:

首先,編譯執(zhí)行也可以通過上面的三類后綴文件名來進(jìn)行分析:

js文件 => 通過fs模塊同步讀取之后,編譯執(zhí)行

node文件 => .node文件是c/c++文件模塊的編譯文件,使用dlopen的方法對文件進(jìn)行加載引入。

json文件 => json文件首先是通過fs讀取文件,然后通過JSON.parse方法進(jìn)行編譯執(zhí)行。
其他后綴名的文件,都會(huì)被當(dāng)成是js文件進(jìn)行處理。同時(shí),我們需要的細(xì)致地分析一下javascript文件編譯的一些具體過程。

javascript文件編譯

在使用fs讀取文件之后,讀取出來的內(nèi)容node會(huì)如何去處理呢?會(huì)造成變量污染嗎?很顯然是不會(huì)的。node是根據(jù)CommonJS的規(guī)范,對讀取進(jìn)入的內(nèi)容,在頭部和尾部進(jìn)行包裝,包裝成function(exports, require, module, __dirname,__filename){ ...讀取內(nèi)容 }。這樣子,就起到了一個(gè)作用域隔絕的作用,不會(huì)對現(xiàn)有模塊中的內(nèi)容污染。而__dirname、__filename是node中存在的。

然后將這個(gè)函數(shù)代碼使用vm原生的模塊runInThisContext()方法執(zhí)行(類似eval => 將字符串轉(zhuǎn)化成可執(zhí)行的js的代碼)。然后返回一個(gè)具體的對象,供現(xiàn)有模塊中的內(nèi)容進(jìn)行使用。

C/C++模塊的編譯

這個(gè)編譯主要是依靠node的process.dlopen()方法進(jìn)行執(zhí)行,同時(shí)node使用libuv對windows和*nix平臺(tái)做了兼容性的處理。這種模塊的性能相對于普通文件模塊來說較高,但是編寫成本也會(huì)相應(yīng)地提高。

json文件編譯

json文件編譯會(huì)比較簡單,就是通過fs讀取文件,然后通過JSON.parse方法進(jìn)行編譯,最終將內(nèi)容給予現(xiàn)有模塊中命名的那個(gè)變量。

總結(jié)

至此我們對node的模塊整體的機(jī)制,大致已經(jīng)整理清楚了,從模塊的導(dǎo)出,到引入,以及標(biāo)識(shí)符的分析。均可從CommonJS中找到影子,但是node對其進(jìn)行的加工又相對比較完美。

如果你對我寫的有疑問,可以評論,如我寫的有錯(cuò)誤,歡迎指正。你喜歡我的博客,請給我關(guān)注Star~呦。大家一起總結(jié)一起進(jìn)步。歡迎關(guān)注我的github博客

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/89182.html

相關(guān)文章

  • 【js基礎(chǔ)】前端模模塊化知識(shí)點(diǎn)整理

    摘要:其中命令用于輸入其他模塊提供的功能,命令用于規(guī)定模塊的對外接口。 簡單記錄下自己對前端模塊化的一些淺薄理解,不對之處歡迎指正 在介紹前端模打包工具之前,我們先簡單說一下瀏覽器、v8和nodejs,因?yàn)槲覀儸F(xiàn)在用到的大部分前端模打包工具,都是需要nodejs環(huán)境運(yùn)行的,同時(shí)他們都能通過npm進(jìn)行下載 1. 瀏覽器: 瀏覽器組成可分兩部分:Shell+內(nèi)核。瀏覽器內(nèi)核又可以分成兩部分:渲染...

    IamDLY 評論0 收藏0
  • nodejs 初入--learnyounode課程總結(jié)(上)

    摘要:編寫一個(gè)簡單的程序,使其能接收一個(gè)或者多個(gè)命令行參數(shù),并且在終端標(biāo)準(zhǔn)輸出中打印出這些參數(shù)的總和。處理所有可能發(fā)生的錯(cuò)誤,并把它們傳遞給回調(diào)函數(shù)。編寫一個(gè)程序來發(fā)起一個(gè)請求,所請求的為命令行參數(shù)的第一個(gè)。 learnyounode 13課總結(jié)(上) 最近對nodejs比較感興趣,但是苦于無法下手,直接啃文檔又覺得十分生硬無趣。 幸好有熱心網(wǎng)友推薦了learnyounode這個(gè)好玩的入...

    masturbator 評論0 收藏0
  • 前端構(gòu)建工具整理

    摘要:常見前端構(gòu)建工具的分類和對比是附帶的包管理器,是內(nèi)置的一個(gè)功能,允許在文件里面使用字段定義任務(wù)在這里,一個(gè)屬性對應(yīng)一段腳本,原理是通過調(diào)用去運(yùn)行腳本命令。 前文 端技術(shù)范圍不斷發(fā)展,前端開發(fā)不僅限于直接編寫html,css和javascript,Web應(yīng)用日益龐大,代碼也更加龐大,因此許多新的思想(例如模塊化和工程化等)和框架(React和Vue等),以及新的語言(Es6 TypeSc...

    leo108 評論0 收藏0
  • 前端模塊化(一)nodeJS中的CommonJS規(guī)范

    摘要:要想讓模塊再次運(yùn)行,必須清除緩存。模塊加載的順序,按照其在代碼中出現(xiàn)的順序。最近參加了公司開展的一次培訓(xùn),結(jié)構(gòu)性思維培養(yǎng)。 序言 模塊化,大家用vue,react等東西,都會(huì)接觸到像exports,module.exports,export,export default,require,define,import等等字段,感覺很多人對于這些東西還是分不清,概念非常的模糊,便想著寫這么一...

    Charlie_Jade 評論0 收藏0
  • 解析nodeJS模塊源碼 親手打造基于ES6的觀察者系統(tǒng)

    摘要:為指定事件注冊一個(gè)單次監(jiān)聽器,即監(jiān)聽器最多只會(huì)觸發(fā)一次,觸發(fā)后立刻解除該監(jiān)聽器。移除指定事件的某個(gè)監(jiān)聽器,監(jiān)聽器必須是該事件已經(jīng)注冊過的監(jiān)聽器。返回指定事件的監(jiān)聽器數(shù)組。如何創(chuàng)建空對象我們已經(jīng)了解到,是要來儲(chǔ)存監(jiān)聽事件監(jiān)聽器數(shù)組的。 毫無疑問,nodeJS改變了整個(gè)前端開發(fā)生態(tài)。本文通過分析nodeJS當(dāng)中events模塊源碼,由淺入深,動(dòng)手實(shí)現(xiàn)了屬于自己的ES6事件觀察者系統(tǒng)。千萬不...

    csRyan 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<