中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在node.js中使用import與export

發布時間:2021-01-18 16:42:34 來源:億速云 閱讀:281 作者:Leah 欄目:web開發

如何在node.js中使用import與export?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

簡述

import與export是es6中模塊化的導入與導出,node.js現階段不支持,需要通過babel進行編譯,使其變成node.js的模塊化代碼。(關于node.js模塊,可參考其他node.js模塊化的文章)

export 曝露

使用export可以曝露出方法、對象、字符串等等,如下代碼

//寫法1
export var foo=function(){
  console.log(1);
}
//寫法2
var bar ={a:"1",b:2};
export {bar};
//寫法3
var baz='hello world';
export {baz as qux};

那么,上面的代碼經過babel的編譯后,變成可以執行的node.js代碼,如下

"use strict";
//標記這個模塊是es的模塊
Object.defineProperty(exports, "__esModule", {
  value: true
});
//寫法1
var foo = exports.foo = function foo() {
  console.log(1);
};
//寫法2
var bar = { a: "1", b: 2 };
exports.bar = bar;
//寫法3

var baz = 'hello world';
exports.qux = baz;

看到上面的代碼我們知道了,es6的export會被轉成node.js中的exports的曝露方式。

import 導入

再來看下import的寫法,我們引入上面寫export的文件xx.js

第一種寫法

import {foo,qux} from './xx';
console.log(qux);

foo,qux是在xx.js中我們曝露出來的屬性,在xx.js中曝露出來的屬性有foo、bar、qux3個,由此可知這種寫法需要知道引入文件中曝露出來的屬性的名稱,并且可以按需要寫,不需要枚舉全部屬性。

下面我們來看下babel編譯后的代碼:

'use strict';
var _ = require('./xx');
console.log(_.qux);

就是一個簡單的require方法,引入xx.js,所以用這種方式我們是可以引入es6的模塊也可以引入node.js模塊的。

第二種寫法

import * as xx from './xx';
console.log(xx.bar);

這里還是引入xx.js,這種寫法會把xx.js中曝露出來的屬性都賦值給xx這個變量(其實就是給module.exports起個別名),被babel編譯后如下下:

'use strict';
var _ = require('./xx');
var xx = _interopRequireWildcard(_);
function _interopRequireWildcard(obj) {
  //判斷是node模塊還是es模塊
  if (obj && obj.__esModule) {
    return obj;
  }
  else {
    var newObj = {};
    if (obj != null) {
      for (var key in obj) { 
        if (Object.prototype.hasOwnProperty.call(obj, key)) 
         newObj[key] = obj[key];
      }
    }
  //兼容舊的babel編譯
    newObj.default = obj;
    console.log(newObj);
    return newObj;
  }
}
console.log(xx.bar);

看到上面的代碼,有一個判斷是node模塊還是es模塊,這種寫法也是兼容es模塊和node的模塊的。

第三種寫法

import oo from './xx'
console.log(oo.bar);

在這種寫法中oo是隨意的變量,乍一看可能會覺的和第二種寫法一樣,其實不然,來看一下編譯后的代碼:

'use strict';
var _ = require('./xx');
var _2 = _interopRequireDefault(_);
function _interopRequireDefault(obj) { 
 return obj && obj.__esModule ? obj : 
 { default: obj }; 
}
console.log(_2.default.bar);

在最后一行,oo.bar被編譯成了_2.default.bar,多了一個default,這里的bar當然就找不到了,所以這種用法不是用來引入export的屬性的,而是下面要說的export default。

export default 曝露且一次性曝露

export與export default我會在別的文章總結,這里我們只說export default的用法,下面來看代碼。

var foo=123;
export default foo;

被babel編譯后

"use strict";
Object.defineProperty(exports, "__esModule", {
 value: true
});
var foo = 123;
exports.default = foo;

看到最后一行foo會被賦給exports.default,這樣正好對應上了import oo from './xx'這種寫法里面會調用default里面的屬性,所以這兩種用法對應使用。既然屬性的值是會賦給exports.default,那么就可以有下面的用法

export default 123;
export default {foo:123};
export default function f(){}
export default function (){}

上面的代碼是分開寫的,因為一個js里面只能使用一次export default,理由和使用module.exports一樣,除了不能寫多個,下面也是錯誤的寫法:

export default var foo=123; //錯誤

export default還可以用來曝露class這里不多說了,都是曝露。

其他的一些用法

繼承

這里說是模塊繼承,其實就是一個父模塊引入子模塊,然后又將子模塊曝露出來的屬性曝露出去:

export * from './xx';

被編譯后

'use strict';
Object.defineProperty(exports, "__esModule", {
 value: true
});
var _ = require('./xx');
Object.keys(_).forEach(function (key) {
 if (key === "default" || key === "__esModule") return;
 Object.defineProperty(exports, key, {
  enumerable: true,
  get: function get() {
   return _[key];
  }
 });
});

注意下面這句

if (key === "default" || key === "__esModule") return;

default屬性不向外曝露...這說明,我們的引入的xx.js這個文件里面用exports default是無效的,替代寫法是

export {default} from './xx';

繼承的寫法常用于組織多個模塊,經常與下面要說的引包一起用

引文件夾(引包)

很多人不理解下面這行代碼

import * as o from './oo'; //oo是個文件

為什么import可以引入文件夾,注意不是什么文件夾都可以,里面至少有一個文件就是index.js或者有package.json和另外名字的js,因為文件夾里面有index.js那么這就不是一個文件夾而是node.js的包了(更多參見node.js包的文章),import會被babel編譯成require,require可以去引用指定路徑的包,因此,import可以去導入一個文件夾,我們可以依賴index.js將文件夾中的其他文件代碼導出,例如:

如何在node.js中使用import與export

//index.js
export * from './1';
export * from './2';

看完上述內容,你們掌握如何在node.js中使用import與export的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

景德镇市| 大石桥市| 磐石市| 普格县| 白山市| 浦城县| 万荣县| 富顺县| 丰镇市| 东乌| 涞水县| 金阳县| 漠河县| 曲周县| 蒲江县| 施甸县| 加查县| 肃北| 元氏县| 全南县| 杂多县| 墨玉县| 榆中县| 荥阳市| 唐山市| 延边| 体育| 平陆县| 平凉市| 巴中市| 仙桃市| 柳河县| 合阳县| 宜良县| 建瓯市| 含山县| 横山县| 富阳市| 仲巴县| 文登市| 铜梁县|