摘要:但是一直沒有在語言層面支持模塊,直到的出現。相信在不久的將來,的模塊一定會全面取代和。的模塊提供了個新的語法,分別是和。就是模塊用來對外暴露數據的接口,具體用法如下。
本文同步自我得博客:http://www.joeray61.com
簡介在當今的Javascript程序中,模塊的作用不言而喻,目前廣泛應用的主要有AMD(瀏覽器端)和CommonJS(服務器端)。但是Javascript一直沒有在語言層面支持模塊,直到ES6的出現。相信在不久的將來,ES6的模塊一定會全面取代AMD和CommonJS。
exportES6的模塊提供了2個新的語法,分別是export和import。export就是模塊用來對外暴露數據的接口,具體用法如下。
export let a = 1; export class A {}; export let b = () => {};
輸出多個數據時不必分別export,可以用一個export統一輸出
let a = 1; class A {}; let b = () => {}; export {a, A, b};import
與export對應,import就是ES6的模塊用來引入數據的命令。
我們先來建立一個數據數據的文件a.js:
// a.js let a = 1; export {a};
然后再創建一個b.js用來導入a.js暴露的數據
// b.js import {a} from "./a"; console.log(a); // 1
如果要導入的模塊暴露了很多變量,而你又不想一個一個地去寫要import的數據時,可以使用*
// b.js import * as obj from "./a"; console.log(obj.a); // 1
需要注意的是,import使用的變量名必須跟export使用的變量名一致
renameimport和export的時候都是可以對變量進行重命名的
// a.js,用于export變量a,但是導出時將a改名為aa let a = 1; export {a as aa};
// b.js用于import從a.js導出的數據aa,但是在導入時將aa改名為b import {aa as b} from "./a"; console.log(a); // undefined console.log(aa); // undefined console.log(b); // 1default
export時可以指定要默認導出的數據
// a.js let a = 1; let aa = 2; export default a; export {aa}; // 也可以寫成 export {a as default, aa};
導入默認數據時需要這樣寫:
// b.js import x from "./a"; console.log(x); // 1
細心的同學可能發現了,這里import的時候使用的變量名是x,這就是default的特權了,導入時使用的變量名可以隨便取,不需要跟導出時的變量名一致。
另外,如果同時要導入default和其他數據時該怎么寫呢?
// b.js import x, {aa} from "./a"; console.log(x); // 1 console.log(aa); // 2ES6模塊加載實質
CommonJS加載模塊時,加載的是值的副本,而ES6的模塊加載,加載的是值的引用。還是直接上代碼吧
// lib.js export let x = 1; export let changeX = () => { x++; };
// a.js import {x, changeX} from "./lib"; changeX(); console.log(x);
// b.js import {x, changeX} from "./lib"; changeX(); console.log(x);
// index.js import "./a"; import "./b";
執行index.js輸出的值是2和3,這就說明a.js和b.js執行的時候改變的都是lib.js里的x,而不是各自操作了一份副本
注意點ES6的模塊采用嚴格模式,無論你是否申明use strict;
import具有提升效果,即使寫在文件的后面,也會被提到頭部首先執行
本文為學習過程中整理,如有問題歡迎交流~
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79803.html
摘要:前端日報精選了解中的全局對象和全局作用域張鑫旭鑫空間鑫生活子進程你應該知道的一切直出內存泄露問題的追查實踐我他喵的到底要怎樣才能在生產環境中用上模塊化騰訊前端大會大咖說大咖干貨,不再錯過發布發布中文翻譯在使用進行本地開發代碼 2017-07-07 前端日報 精選 了解JS中的全局對象window.self和全局作用域self ? 張鑫旭-鑫空間-鑫生活Node.js 子進程:你應該知道...
摘要:注解的元數據選擇器頁面渲染時,組件匹配的選擇器使用方式采用標簽的方式。當然必要的,在需要用到的的模塊中引入引入的指令,放在聲明里面引入的模塊引導應用的根組件關于的元數據還未完全,所以后面會繼續完善。 angular學習筆記之組件篇 showImg(https://i.imgur.com/NQG0KG1.png); 1注解 1.1組件注解 @Component注解,對組件進行配置。 1....
摘要:注解的元數據選擇器頁面渲染時,組件匹配的選擇器使用方式采用標簽的方式。當然必要的,在需要用到的的模塊中引入引入的指令,放在聲明里面引入的模塊引導應用的根組件關于的元數據還未完全,所以后面會繼續完善。 angular學習筆記之組件篇 showImg(https://i.imgur.com/NQG0KG1.png); 1注解 1.1組件注解 @Component注解,對組件進行配置。 1....
摘要:學習筆記頂層對象雖然是筆記但是基本是抄了一次大師的文章了頂層對象頂層對象,在瀏覽器環境指的是對象,在指的是對象。之中,頂層對象的屬性與全局變量是等價的。的寫法模塊的寫法上面代碼將頂層對象放入變量。參考引用頂層對象實戰 es6學習筆記-頂層對象_v1.0 (雖然是筆記,但是基本是抄了一次ruan大師的文章了) 頂層對象 頂層對象,在瀏覽器環境指的是window對象,在Node指的是gl...
閱讀 3774·2021-11-11 11:02
閱讀 3505·2021-10-11 10:57
閱讀 3616·2021-09-22 16:00
閱讀 1853·2021-09-02 15:15
閱讀 1337·2019-08-30 15:56
閱讀 1016·2019-08-30 15:54
閱讀 2738·2019-08-30 12:43
閱讀 3547·2019-08-29 16:06