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

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

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

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

在另一個文件中你這樣引用
復制代碼 代碼如下:

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

那到底Module.exports是什么呢?它是否合法呢?
其實,Module.exports才是真正的接口,exports只不過是它的一個輔助工具。 最終返回給調(diào)用的是Module.exports而不是exports。

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

修改rocker.js如下:
復制代碼 代碼如下:

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

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

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

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

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

下面例子中,你的模塊是一個類:
復制代碼 代碼如下:

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)用它:
復制代碼 代碼如下:

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

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

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

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

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

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

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

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

同樣,exports是這樣的
復制代碼 代碼如下:

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

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

相關(guān)文章

  • js多線程解決方案Web?Worker簡單說明與實例演示

    js多線程解決方案Web?Worker簡單說明與實例演示

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

    徹底搞懂?javascript的Promise

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

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

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

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

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

    超詳細的JavaScript基本語法規(guī)則

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

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

    下面小編就為大家?guī)硪黄贘S腳本語言的基礎(chǔ)語法詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • javascript中new關(guān)鍵字詳解

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

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

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

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

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

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

    解析DHTML,JavaScript,DOM,BOM以及WEB標準的描述

    本篇文章是對DHTML,JavaScript,DOM,BOM以及WEB標準進行了詳細的描述介紹,需要的朋友參考下
    2013-06-06

最新評論