摘要:在中是有這種寫法的,我們稱為語法,就是通過關鍵詞,引入所要依賴的文件。的語法的用法所有模塊都通過來定義通過引入依賴通過對外提供接口或者通過提供整個接口的語法的模塊功能主要通過兩個關鍵字來實現和。是用來聲明模塊的默認接口的。
你帶著你的同事聯調的時候
????
從古至今,Javascript都沒有自帶的模塊體系,能做的,也就只是將不同作用的代碼寫在不同的JS文件中,然后通過分別引入。這樣做又一個非常致命的問題,那就是我們要定位一個方法變得非常的困難。
一個靈活的模塊體系,能讓你的代碼之間的依賴關系更加直觀,一個好的模塊式的寫法讓沒個方法都能很快的找到聲明位置所在。
在NODE中是有這種寫法的,我們稱為CMD語法,就是通過require關鍵詞,引入所要依賴的文件。
當然,隨著前端在WEB開發中占據的比重越來越高,客戶端JS的模塊化也尤為重要。其實已經有比較成熟的前端框架來實現這個功能,比如RequireJs和Seajs。ES6的出現,讓JS實現模塊功能變得更?加簡單。
//requirejs的語法 define(["moudleA"], function(){ function foo(){ doSomething(); } return { foo : foo }; }); //seajs的用法 // 所有模塊都通過 define 來定義 define(function(require, exports, module) { // 通過 require 引入依賴 var $ = require("jquery"); var Spinning = require("./spinning"); // 通過 exports 對外提供接口 exports.doSomething = ... // 或者通過 module.exports 提供整個接口 module.exports = ... });ES6的Module語法
ES6的模塊功能主要通過兩個關鍵字來實現export和import。
從字面上不難看出,export是輸出,即用來將模塊內部的方法暴露出來,而import是輸入,即引入其他模塊的方法,便于在本模塊中調用其他模塊的方法。
正常來講,我們可以將每個模塊都寫成一個獨立的文件,由于Javascript作用域的問題,每個模塊內部的變量及方法都是私有的,即只能內部訪問,外部無法訪問。要想使模塊內部的方法可以從外部訪問,就必須使用export關鍵字。
//moduleA.js var moduleA1 = "a"; var moduleA2 = "aa"; function moduleFunc(){ console.log(moduleA2); } export { moduleA1, moduleA2 as moduleA, moduleFunc as module };
如上面的代碼所示,在模塊中聲明了變量和方法,我們只需要將變量名或者方法名,置于export的作用下,就可以被其他模塊使用。
as關鍵詞可以用來重命名,上面的例子中moduleA就等于moduleA2。
這里需要注意的是,export定義的是對外的接口,接口必須在模塊內部被聲明或實現過,不然就會報錯。
var a = 1; export a;//不報錯 export b;//報錯
使用export定義了模塊的接口之后,其他模塊就可以通過import命令來引入這個模塊
//moduleB.js import {moduleA1, moduleA} from "./moduleA.js"; import {module as moduleFunc} from "./moduleA.js"; moduleFunc();
如上面的代碼所示,通過import關鍵字從moduleA.js中引入了moduleA1、moduleA2、moduleFunc()三個變量,這樣在這個模塊中就能使用A模塊中的變量了。
需要注意的是,import關鍵字有提升效果,也就是無論寫在哪個位置,都和寫在模塊頂部效果一樣。import加載模塊的過程是在編譯階段執行的,代碼運行之前就已經完成了加載過程。
如果我們需要引入一個模塊中的所有變量,可以用下面的方法
//moduleC.js import * as module from "./moduleA.js"; module.moduleA;//"a" module.moduleFunc();//"aa"
另外,import加載的文件是不會重復加載的
//moduleD.js import {moduleA1} from "./moduleA.js"; import {moduleA2} from "./moduleA.js"; //等同于 import {moduleA1, moduleA2} from "./moduleA.js";
moduleA.js只會加載一次。
export default是用來聲明模塊的默認接口的。
//hello.js var name = "dahan"; function sayHello(){ console.log("Hello"); } export default sayHello; //person.js import hello from "./hello.js"; hello(); //"Hello"
使用export default聲明的接口,引入的時候不需要使用大括號,也不用指定特定的變量名。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/91711.html
摘要:前端培訓初級階段語法變量值類型運算符語句前端培訓初級階段內置對象函數基礎內容知識我們會用到。模塊定義加載模塊繼承中的繼承依賴于原型鏈繼承。 前端最基礎的就是 HTML+CSS+Javascript。掌握了這三門技術就算入門,但也僅僅是入門,現在前端開發的定義已經遠遠不止這些。前端小課堂(HTML/CSS/JS),本著提升技術水平,打牢基礎知識的中心思想,我們開課啦(每周四)。 該文為前...
摘要:,微軟發布,同時發布了,該語言模仿同年發布的。,公司在瀏覽器對抗中沒落,將提交給國際標準化組織,希望能夠成為國際標準,以此抵抗微軟。同時將標準的設想定名為和兩類。,尤雨溪發布項目。,正式發布,并且更名為。,發布,模塊系統得到廣泛的使用。 前言 作為程序員,技術的落實與鞏固是必要的,因此想到寫個系列,名為 why what or how 每篇文章試圖解釋清楚一個問題。 這次的 why w...
摘要:以下簡稱是語言的下一代標準。因為當前版本的是在年發布的,所以又稱。命令用于規定模塊的對外接口,命令用于輸入其他模塊提供的功能。需要特別注意的是,命令規定的是對外的接口,必須與模塊內部的變量建立一一對應關系。 ECMAScript 6(以下簡稱ES6)是JavaScript語言的下一代標準。因為當前版本的ES6是在2015年發布的,所以又稱ECMAScript 2015。 最常用的ES6...
摘要:的主要思想是異步模塊,主邏輯在回調函數中執行,這和瀏覽器前端所習慣的開發方式不謀而合,應運而生。是目前開發中使用率最高的模塊化標準。 原文鏈接: http://yanjiie.me 偶然的一個周末復習了一下 JS 的模塊標準,刷新了一下對 JS 模塊化的理解。 從開始 Coding 以來,總會周期性地突發奇想進行 Code Review。既是對一段時期的代碼進行總結,也是對那一段時光的...
摘要:感謝感謝和在推動模塊化發展方面做出的貢獻。與引用阮一峰老師的標準參考教程規范加載模塊是同步的,也就是說,只有加載完成,才能執行后面的操作。規定了新的模塊加載方案。與引用阮一峰老師的入門它們有兩個重大差異。 前言 本篇我們重點介紹以下四種模塊加載規范: AMD CMD CommonJS ES6 模塊 最后再延伸講下 Babel 的編譯和 webpack 的打包原理。 require....
閱讀 2495·2021-11-15 18:14
閱讀 1720·2021-10-14 09:42
閱讀 3760·2021-10-11 10:58
閱讀 3961·2021-10-09 09:44
閱讀 2421·2021-09-26 09:55
閱讀 2443·2021-09-24 10:38
閱讀 2035·2021-09-04 16:48
閱讀 3276·2021-09-02 15:21