欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

nodejs中exports與module.exports的區(qū)別詳細(xì)介紹

 更新時(shí)間:2013年01月14日 17:59:29   作者:  
你肯定非常熟悉nodejs模塊中的exports對(duì)象,你可以用它創(chuàng)建你的模塊接下來(lái)介紹創(chuàng)建過(guò)程,感興趣的朋友可以參考下
你肯定非常熟悉nodejs模塊中的exports對(duì)象,你可以用它創(chuàng)建你的模塊。例如:(假設(shè)這是rocker.js文件)
復(fù)制代碼 代碼如下:

exports.name = function() {
console.log('My name is Lemmy Kilmister');
};

在另一個(gè)文件中你這樣引用
復(fù)制代碼 代碼如下:

var rocker = require('./rocker.js');
rocker.name(); // 'My name is Lemmy Kilmister'

那到底Module.exports是什么呢?它是否合法呢?
其實(shí),Module.exports才是真正的接口,exports只不過(guò)是它的一個(gè)輔助工具?!∽罱K返回給調(diào)用的是Module.exports而不是exports。

所有的exports收集到的屬性和方法,都賦值給了Module.exports。當(dāng)然,這有個(gè)前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經(jīng)具備一些屬性和方法,那么exports收集來(lái)的信息將被忽略。

修改rocker.js如下:
復(fù)制代碼 代碼如下:

module.exports = 'ROCK IT!';
exports.name = function() {
console.log('My name is Lemmy Kilmister');
};

再次引用執(zhí)行rocker.js
復(fù)制代碼 代碼如下:

var rocker = require('./rocker.js');
rocker.name(); // TypeError: Object ROCK IT! has no method 'name'

發(fā)現(xiàn)報(bào)錯(cuò):對(duì)象“ROCK IT!”沒(méi)有name方法
rocker模塊忽略了exports收集的name方法,返回了一個(gè)字符串“ROCK IT!”。由此可知,你的模塊并不一定非得返回“實(shí)例化對(duì)象”。你的模塊可以是任何合法的javascript對(duì)象--boolean, number, date, JSON, string, function, array等等。

你的模塊可以是任何你設(shè)置給它的東西。如果你沒(méi)有顯式的給Module.exports設(shè)置任何屬性和方法,那么你的模塊就是exports設(shè)置給Module.exports的屬性。

下面例子中,你的模塊是一個(gè)類:
復(fù)制代碼 代碼如下:

module.exports = function(name, age) {
this.name = name;
this.age = age;
this.about = function() {
console.log(this.name +' is '+ this.age +' years old');
};
};

可以這樣應(yīng)用它:
復(fù)制代碼 代碼如下:

var Rocker = require('./rocker.js');
var r = new Rocker('Ozzy', 62);
r.about(); // Ozzy is 62 years old

下面例子中,你的模塊是一個(gè)數(shù)組:
復(fù)制代碼 代碼如下:

module.exports = ['Lemmy Kilmister', 'Ozzy Osbourne', 'Ronnie James Dio', 'Steven Tyler', 'Mick Jagger'];

可以這樣應(yīng)用它:
復(fù)制代碼 代碼如下:

var rocker = require('./rocker.js');
console.log('Rockin in heaven: ' + rocker[2]); //Rockin in heaven: Ronnie James Dio

現(xiàn)在你明白了,如果你想你的模塊是一個(gè)特定的類型就用Module.exports。如果你想的模塊是一個(gè)典型的“實(shí)例化對(duì)象”就用exports。

給Module.exports添加屬性類似于給exports添加屬性。例如:
復(fù)制代碼 代碼如下:

module.exports.name = function() {
console.log('My name is Lemmy Kilmister');
};

同樣,exports是這樣的
復(fù)制代碼 代碼如下:

exports.name = function() {
console.log('My name is Lemmy Kilmister');
};

請(qǐng)注意,這兩種結(jié)果并不想同。前面已經(jīng)提到module.exports是真正的接口,exports只不過(guò)是它的輔助工具。推薦使用exports導(dǎo)出,除非你打算從原來(lái)的“實(shí)例化對(duì)象”改變成一個(gè)類型。

相關(guān)文章

  • js多線程解決方案Web?Worker簡(jiǎn)單說(shuō)明與實(shí)例演示

    js多線程解決方案Web?Worker簡(jiǎn)單說(shuō)明與實(shí)例演示

    這篇文章主要介紹了js多線程解決方案Web?Worker,他是HTML5提供的一個(gè)JavaScript多線程解決方案,我們可以將一些大計(jì)算量的代碼交由web Worker運(yùn)行而不凍結(jié)用戶界面
    2023-02-02
  • 徹底搞懂?javascript的Promise

    徹底搞懂?javascript的Promise

    這篇文章主要為大家詳細(xì)介紹了javascript的Promise,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • 解決js正則匹配換行問(wèn)題實(shí)現(xiàn)代碼

    解決js正則匹配換行問(wèn)題實(shí)現(xiàn)代碼

    js正則匹配換行過(guò)程中會(huì)出現(xiàn)很多的問(wèn)題,本文將提供詳細(xì)的解決方法,需要的朋友可以參考下
    2012-12-12
  • TypeScript具有的幾個(gè)不同特質(zhì)

    TypeScript具有的幾個(gè)不同特質(zhì)

    這篇文章主要介紹了TypeScript具有的幾個(gè)不同特質(zhì),首先我們先來(lái)看看什么是TypeScript呢?TypeScript是微軟推出的一個(gè)開(kāi)源語(yǔ)言,用于開(kāi)發(fā)大型JS應(yīng)用程序。其作者是大名鼎鼎的C#之父Anders Hejlsberg。
    2015-04-04
  • 超詳細(xì)的JavaScript基本語(yǔ)法規(guī)則

    超詳細(xì)的JavaScript基本語(yǔ)法規(guī)則

    這篇文章主要介紹了JavaScript基本語(yǔ)法規(guī)則,保姆級(jí)的詳細(xì)教程,萬(wàn)字長(zhǎng)文詳細(xì)的列出了JavaScript的各種語(yǔ)法,建議收藏系列,希望可以有所幫助
    2021-08-08
  • 基于JS腳本語(yǔ)言的基礎(chǔ)語(yǔ)法詳解

    基于JS腳本語(yǔ)言的基礎(chǔ)語(yǔ)法詳解

    下面小編就為大家?guī)?lái)一篇基于JS腳本語(yǔ)言的基礎(chǔ)語(yǔ)法詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • javascript中new關(guān)鍵字詳解

    javascript中new關(guān)鍵字詳解

    本文給大家詳細(xì)介紹了下javascript中new關(guān)鍵字的使用方法,以及javascript 使用new關(guān)鍵字的區(qū)別,有需要的小伙伴可以參考下。
    2015-12-12
  • JavaSciprt中處理字符串之sup()方法的使用教程

    JavaSciprt中處理字符串之sup()方法的使用教程

    這篇文章主要介紹了JavaSciprt中處理字符串之sup()方法的使用教程,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-06-06
  • JavaScript獲取各大瀏覽器信息圖示

    JavaScript獲取各大瀏覽器信息圖示

    這篇文章主要介紹了JavaScript獲取各大瀏覽器信息圖示的相關(guān)資料,需要的朋友可以參考下
    2015-11-11
  • 解析DHTML,JavaScript,DOM,BOM以及WEB標(biāo)準(zhǔn)的描述

    解析DHTML,JavaScript,DOM,BOM以及WEB標(biāo)準(zhǔn)的描述

    本篇文章是對(duì)DHTML,JavaScript,DOM,BOM以及WEB標(biāo)準(zhǔn)進(jìn)行了詳細(xì)的描述介紹,需要的朋友參考下
    2013-06-06

最新評(píng)論