首頁 >web前端 >前端問答 >nodejs exports用法

nodejs exports用法

WBOY
WBOY原創
2023-05-14 10:31:06931瀏覽

Node.js是一種基於Chrome V8引擎的讓JavaScript運行在服務端的程式語言,它可以使用模組和套件的方式,方便地組織程式並管理依賴。其中module.exportsexports是模組化常用的概念,本文將介紹它們在Node.js中的用法。

module.exports和exports的關係式

在Node.js中,每個檔案就是一個獨立的模組,想要在其它模組中使用該檔案內部的變數和函數,需要將其導出。 module.exportsexports這兩個變數都可以進行匯出運算。

在Node.js中,每個模組都有一個module對象,該對象包含了模組的相關信息,其中就有一個exports屬性。 exports將要匯出的變數或函數掛載在該屬性上,然後透過require()函數在外部引用該模組並呼叫其導出的變數和函數。

預設情況下,exports指向的是module.exports的引用,所以透過exportsmodule.exports都可以進行模組導出,但是需要注意的是,二者的指向關係不是一直相同的,導致有時候我們需要使用module.exports而不是exports

對比exports和module.exports

當我們使用exports匯出一個物件時,實際上是向exports新增了一個屬性並賦值。例如:

// add.js
exports.add = function (a, b) {
  return a + b;
}

上述程式碼中,我們使用exportsadd()方法匯出。相當於執行了以下程式碼:

exports.add = function (a, b) {
  return a + b;
}

module.exports = exports; // exports被默认指向module.exports

接下來讓我們看一個範例:

// math.js
exports.add = function (a, b) {
  return a + b;
};

exports.sub = function (a, b) {
  return a - b;
};

// app.js
const math = require('./math');
console.log(math.add(1, 1)); // 2
console.log(math.sub(1, 1)); // 0

透過require()函數引用math模組並呼叫其導出的方法,結果正確輸出。為什麼是正確的呢?

我們知道exports預設指向module.exports,而當我們直接將exports指向一個新的物件時,module .exports的指向關係就已經被改變了。而Node.js在載入模組時,實際上返回的是module.exports對象而不是exports對象,所以將exports指向一個新的對象後,再將該新物件作為module.exports的值,才是真正的匯出運算。

exports = {
  add: function (a, b) {
    return a + b;
  },
  sub: function (a, b) {
    return a - b;
  },
}

module.exports = exports;

注意:如果只是給exports的屬性重新賦值,並不會改變它和module.exports之間的指向關係。

例如:

// multiply.js
exports = {
  mul: function (a, b) {
    return a * b;
  }
}

// app.js
const multiply = require('./multiply');
console.log(multiply.mul(2, 5)); // TypeError: multiply.mul is not a function

在上述程式碼中,將exports指向了一個新的對象,但是沒有對其屬性進行賦值,所以導出的值為undefined,所以在呼叫時會出現TypeError。

exports和module.exports的使用場景

在大多數情況下,我們可以直接使用exports進行模組匯出。但是有時候,我們需要將模組直接導出一個函數或對象,而不是將它們掛載在exports上,此時就需要使用module.exports了。

例如:

// foo.js
module.exports = function () {
  console.log('Hello World!')
}

// app.js
const foo = require('./foo');
foo(); // Hello World!

在上述程式碼中,直接將一個函數賦值給module.exports,實際上是將函數作為整個模組的匯出物件。

小結

exports和module.exports都是Node.js中用於導出模組的變量,可以透過它們將模組的變數或函數暴露給外部使用,在使用的過程中,需要注意exports預設指向module.exports,其關係並非一直指向同一個對象,導致有時候我們需要使用module.exports而不是exports。在選用使用exports和module.exports導出模組的時候,可以依照實際情況進行選擇。

以上是nodejs exports用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn