您好,登錄后才能下訂單哦!
這篇文章主要介紹CommonJS規(guī)范有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
寫在前面:
一個文件就是一個模塊。
另外本文中的示例代碼需要在node.js環(huán)境中方可正常運行,否則將出現(xiàn)錯誤。事實上ES6已經(jīng)出現(xiàn)了模塊規(guī)范,如果使用ES6的模塊規(guī)范是無需node.js環(huán)境的。因此,需要將commonJS規(guī)范和ES6的模塊規(guī)范區(qū)分開來。
一、為什么制定CommonJS規(guī)范?
在后端,JavaScript的規(guī)范遠遠落后并且有很多缺陷,這使得難以使用JavaScript開發(fā)大型應(yīng)用。比如:
沒有模塊系統(tǒng)
標準庫較少
沒有標準接口
缺乏包管理系統(tǒng)
列表內(nèi)容
CommonJS規(guī)范的提出,主要是為了彌補JavaScript沒有標準的缺陷,已達到像Python、Ruby和Java那樣具備開發(fā)大型應(yīng)用的基礎(chǔ)能力,而不是停留在開發(fā)瀏覽器端小腳本程序的階段。
二、CommonJS模塊規(guī)范
CommonJS模塊規(guī)范主要分為三部分:模塊引用、模塊定義、模塊標識。
1、模塊引用
如果在a.js文件中使用如下語句
var math=require('math');
意為使用require()方法,引入math模塊,并賦值給變量math。事實上,命名的變量名和引入的模塊名不必相同,就像這樣:
var Math=require('math');
賦值的意義在于,a.js中將僅能識別Math,因為這是已經(jīng)定義的變量,并不能識別math,因為math沒有定義。
帶路徑和不帶路徑
上面例子中require的參數(shù)僅僅是模塊名字的字符串,沒有帶有路徑,引用的是a.js所在當前目錄下的node_modules目錄下的math模塊。如果當前目錄沒有node_modules目錄或者node_modules目錄里面沒有安裝math模塊,便會報錯。
如果要引入的模塊在其他路徑,就需要使用到相對路徑或者絕對路徑,例如:
var add=require('./add.js')
上面例子中引入了當前目錄下的add.js文件,并賦值給add變量。
2、模塊定義
module對象:在每一個模塊中,module對象代表該模塊自身。
export屬性:module對象的一個屬性,它向外提供接口。
仍然采用上一個示例,假設(shè)add.js中的代碼如下:
function add(num1,num2){ alert(num1+num2); }
盡管a.js文件引入了add.js文件,前者卻仍然無法使用后者中的add函數(shù),在a.js文件中add(3,5)這樣的代碼會報錯,提示add不是一個函數(shù)。
add.js中的函數(shù)要能被其他模塊使用,就需要暴露一個對外的接口,export屬性用于完成這一工作。將add.js中代碼改為如下:
exports.add=function (num1,num2){ alert(num1+num2); }
a.js文件就可以正常調(diào)用add.js中的方法,例如add.add(3,5)這樣的調(diào)用能夠正常執(zhí)行,前一個add意為本文件中add變量代表的模塊,后一個add是引入模塊的add方法。
3、模塊標識
模塊標識指的是傳遞給require方法的參數(shù),必須是符合小駝峰命名的字符串,或者以 . 、.. 、開頭的相對路徑,或者絕對路徑。
三、CommonJS模塊規(guī)范的好處
CommonJS模塊規(guī)范很好地解決變量污染問題,每個模塊具有獨立空間,互不干擾,命名空間等方案與之相比相形見絀。
CommonJS規(guī)范定義模塊十分簡單,接口十分簡潔。
CommonJS模塊規(guī)范支持引入和導出功能,這樣可以順暢地連接各個模塊,實現(xiàn)彼此間的依賴關(guān)系。
以上是“CommonJS規(guī)范有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。