module.exports,exports,export和export default,import與require區別與聯繫【原創】

来源:http://www.cnblogs.com/Nutrient-rich/archive/2017/06/21/7059821.html
-Advertisement-
Play Games

module.exports,exports,export和export default,import與require區別與聯繫 ...


還在為module.exports、exports、export和export default,import和require區別與聯繫發愁嗎,這一篇基本就夠了!

一、首先搞清楚一個基本問題:

module.exportsexports是屬於CommonJS模塊規範!(不清楚commonjs?大神請這邊逛一逛commonjs規範

exportexport default是屬於ES6語法(不清楚ES6?大神請這邊逛一逛ES6模塊

同樣importrequire分別屬於ES6和CommonJS!

二、知道屬於哪一塊的語法了還有一個明確點:

module.exportsexports、exportexport default都是導出模塊;

importrequire則是導入模塊。

所以現在就不要弄混了,module.exports導出對應require導入,export導出對應import導入。

喂!等等,怎麼才說到module.exports導出對應require導入,export導出對應import導入,那還有exports和export default呢!?那我們繼續。

三、module.exportsexports的區別與聯繫

講到這裡就不得不稍微提一下模塊化:

Node應用由模塊組成,採用CommonJS模塊規範。

 

根據這個規範,每個文件就是一個模塊,有自己的作用域。在一個文件裡面定義的變數、函數、類,都是私有的,對其他文件不可見。

CommonJS規範規定,每個模塊內部,module變數代表當前模塊。這個變數是一個對象,它的exports屬性(即module.exports)是對外的介面。載入某個模塊,其實是載入該模塊的module.exports屬性。

var x = 5;
var addX = function (value) {
  return value + x;
};
module.exports.x = x;
module.exports.addX = addX;

上面代碼通過module.exports輸出變數x和函數addX

require方法用於載入模塊。

var example = require('./example.js');

console.log(example.x); // 5
console.log(example.addX(1)); // 6

 

看了剛剛這段commonjs規範上面的介紹可以知道以下區別與聯繫:

 

其實exports變數是指向module.exports,載入模塊實際是載入該模塊的module.exports。這等同在每個模塊頭部,有一行這樣的命令。

 

var exports = module.exports;

 

於是我們可以直接在 exports 對象上添加方法,表示對外輸出的介面,如同在module.exports上添加一樣。註意,不能直接將exports變數指向一個值,因為這樣等於切斷了exports與module.exports的聯繫。

三、exportexport default的區別與聯繫

模塊功能主要由:exportimport構成export導出模塊的對外介面,import命令導入其他模塊暴露的介面。

export其實和export default就是寫法上面有點差別,一個是導出一個個單獨介面,一個是預設導出一個整體介面。使用import命令的時候,用戶需要知道所要載入的變數名或函數名,否則無法載入。這裡就有一個簡單寫法不用去知道有哪些具體的暴露介面名,就用export default命令,為模塊指定預設輸出。

export可以這樣寫

// testA.js
var f = 'Miel';
var name = 'Jack';
var data= 1988;

export {f, name, data};

使用export命令定義了模塊的對外介面以後,其他 JS 文件就可以通過import命令載入這個模塊。

// main.js
import {f, name, data} from './testA';

export default可以這樣寫

// export-default.js
export default function () {
  console.log('foo');
}
// 或者寫成

function foo() {
  console.log('foo');
}
export default foo;
// import-default.js
import customName from './export-default';
customName(); // 'foo'

下麵比較一下export default和export 輸出。

// 第一組
export default function car() { // 輸出
  // ...
}

import car from 'car'; // 輸入

// 第二組
export function car2() { // 輸出
  // ...
};

import {car2} from 'car2'; // 輸入

可以看到第一組是使用export defaultimport語句不需要使用大括弧;第二組使用export,對應的import語句需要使用大括弧,一個模塊只能有一個預設輸出,所以export default只能使用一次。

四、import和require的區別與聯繫

看了上面其實已經清楚了,import和require是分別屬於ES6和CommonJS的兩種導入模塊的語法而已。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JavaScript--語法3--數組 一、心得 二、代碼 ...
  • JavaScript--練習1--99乘法表 一、心得 二、代碼 如果不加css的話,沒有邊線和600px ...
  • 在CSS中margin是指從自身邊框到另一個容器邊框之間的距離,就是容器外距離。在CSS中padding是指自身邊框到自身內部另一個容器邊框之間的距離,就是容器內距離。 下麵講解 padding和margin常用的用法 一、padding 1、語法結構 (1)padding-left:10px; 左 ...
  • JavaScript--語法2 一、心得 判斷的時候常量放左邊java中switch只支持四種類型,javaScript是弱類型,所有的都支持。 顯示方法: 二、代碼 ...
  • 1、基本類型與引用類型 基本類型:值保存在變數中 (Number、String、Boolean、Undefined、Null)。在記憶體中占據固定大小空間,被保存在棧記憶體中 引用類型:值是保存在記憶體中的對象;操作對象實際操作的是對象的引用而不是實際的對象。保存在堆記憶體中 複製變數值: 傳遞參數:ECM ...
  • JavaScript--語法1 一、心得 JavaScript語法:變數聲明 var弱類型 var中可以是任何類型在JavaScript裡面,單&單|是位運算符。變數沒有值使用的話就是undefine(常量) 二、代碼 ...
  • 最近在學習vue,涉及到axios的ajax操作,記錄一下相關Config,方便日後查閱 { // `url`是將用於請求的伺服器URL url: '/user', // `method`是發出請求時使用的請求方法 method: 'get', // 預設 // `baseURL`將被添加到`url ...
  • html css js 效果圖 實現原理 首先是用mousedown()滑鼠按下事件保存一個狀態值,mouseup()滑鼠抬起事件取消該狀態,再同時配合mousemove()滑鼠移動事件,實現按住拖動的效果。 在滑鼠移動的同時去改變精度條的長度和按鈕的相對左部的距離。 然後就是距離的計算,主要利用的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...