摘要:一一開始是垃圾,但隨著時代的發展業務的進步,變得越來越重要,但涉及之初就是用來打雜的,有缺陷如下簡單翻譯下沒有模塊系統沒有標準庫沒有文件沒有系統沒有標準接口,用來做服務器或者數據庫沒有依賴包管理系統。
一 Commonjs
一開始js是垃圾,但隨著時代的發展、業務的進步,js變得越來越重要,但js涉及之初就是用來打雜的,有缺陷如下:
JavaScript has no module system. To compose JavaScript scripts, they must be either managed in HTML, concatenated, injected, or manually fetched and evaluated. There is no native facility for scope isolation or dependency management.
JavaScript has no standard library. It has a browser API, dates, and math, but no file system API, much less an IO stream API or primordial types for binary data.
JavaScript has no standard interfaces for things like Web servers or databases.
JavaScript has no package management system that manages dependencies and automatically installs them, except JSAN (not to be confused with JSON), which falls short for scope isolation.
簡單翻譯下:
沒有模塊系統
沒有標準庫、沒有文件、沒有IO系統
沒有標準接口,用來做服務器、或者數據庫
沒有依賴包管理系統。
所以mozila的工程師希望來解決這個問題
“What I’m describing here is not a technical problem. It’s a matter of people getting together and making a decision to step forward and start building up something bigger and cooler together.”
這并不是一個技術問題,而是為了便于更多人合作...
所以就有了commonjs,定義了這些概念,而nodejs實現了這個標準。
CommonJS定義的模塊分為:{模塊引用(require)} {模塊定義(exports)} {模塊標識(module)}
比如這個樣子:
// foo.js module.exports = function(x) { console.log(x); }; // main.js var foo = require("./foo"); foo("Hi");
看似完美的解決了模塊問題,但在瀏覽器模式下是不行的,假設我們有如下這段代碼
var math = require("math"); math.add(2, 3);
問題1:math.add會被阻塞掉,必須在require完成之后再執行
問題2:即使能夠異步加載,但你如何能夠知道什么時候加載完畢,什么時候能夠執行完么?
(Asynchronous Module Definition) 異步模塊加載
這里不得不說到我們的requirejs,它有兩個參數
require([module], callback);
第一個表示依賴的模塊,第二個就是具體的回掉了,比如上上述的代碼
require(["math"], function (math) { math.add(2, 3); });三 ES6
ES6中的模塊最大的特點就是靜態,即在編譯時就確定依賴關系,ES6中會自然采用嚴格模式:
變量必須聲明后再使用
函數的參數不能有同名屬性,否則報錯
不能使用with語句
不能對只讀屬性賦值,否則報錯
不能使用前綴0表示八進制數,否則報錯
不能刪除不可刪除的屬性,否則報錯
不能刪除變量delete prop,會報錯,只能刪除屬性delete global[prop]
eval不會在它的外層作用域引入變量
eval和arguments不能被重新賦值
arguments不會自動反映函數參數的變化
不能使用arguments.callee
不能使用arguments.caller
禁止this指向全局對象
不能使用fn.caller和fn.arguments獲取函數調用的堆棧
增加了保留字(比如protected、static和interface)
參考:http://www.cnblogs.com/chengu...
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/85000.html
摘要:是一個小巧的模塊載入框架,壓縮后,具有輕量級異步加載模塊等特點。通過和關鍵字,旨在建立客戶端和服務器端通用的加載規范。 隨著應用復雜度的攀升,常規的JavaScript引入方式(script標簽)已經不能滿足需求,模塊化管理成為團隊協作的高效方法,現在的模塊化管理主要有RequireJS、AMD、CMD、CommonJS、ES6四種模式。 RequireJS是一個小巧的JavaScri...
摘要:所有依賴這個模塊的語句,都定義在一個回調函數中,等到加載完成之后,這個回調函數才會運行。也采用語句加載模塊,但是不同于,它要求兩個參數第一個參數,是一個數組,里面的成員就是要加載的模塊第二個參數,則是加載成功之后的回調函數。 本篇文章來自對文章《js模塊化編程之徹底弄懂CommonJS和AMD/CMD!》的總結,大部分摘自文章原話,本人只是為了學習方便做的筆記,之后有新的體會會及時補充...
摘要:若不存在則模塊標識應該默認定義為在加載器中被請求腳本的標識。其中是一個數組,里面的成員就是要加載的模塊是模塊加載完成之后的回調函數。在加載與兩個模塊之后執行回調函數實現具體過程。在判斷是否支持是否存在,存在則使用方式加載模塊。 我的github(PS:希望star): https://github.com/tonyzheng1... 今天由于項目中引入的echarts的文件太大,req...
閱讀 3662·2021-10-11 10:58
閱讀 2252·2021-10-08 10:05
閱讀 2034·2021-09-27 13:34
閱讀 3576·2019-08-30 15:53
閱讀 2734·2019-08-30 14:02
閱讀 3562·2019-08-29 16:55
閱讀 623·2019-08-29 15:41
閱讀 1071·2019-08-29 15:23