關(guān)于我們
書單推薦
新書推薦
|
深入理解ES6
在整個JavaScript語言的發(fā)展歷史中,ECMAScript 6代表了最大的核心變化。最新的ECMAScript 6不僅增加了新的對象類型,還添加了新的語法和令人興奮的新功能。通過多年的研究和討論,ECMAScript 6在2014年達(dá)到了功能完善的狀態(tài)。但是要讓所有的JavaScript環(huán)境都能支持ECMAScript 6還需要一段時(shí)間,因此還是有必要了解即將出現(xiàn)的以及已經(jīng)可用的功能。
√ 不識老尼,枉為前端攻城獅,其成名作《JS高級程序設(shè)計(jì)》曾名動江湖。
√ Redux締造者與React核心成員作序力薦,盛贊本書對JS的剖析無人企及。
√ 用直截了當(dāng)?shù)姆绞絺鬟_(dá)艱深的技術(shù)細(xì)節(jié),對技術(shù)的理解方可高效送達(dá)。
√ 中高級開發(fā)者藉由本書可一舉邁入對標(biāo)準(zhǔn)及其未來特性熟稔于心之化境。
譯者序
十年前誰也無法料到,彼時(shí)只能寫小動畫的玩具語言JavaScript竟會有如今之威力,這愈發(fā)顯現(xiàn)出Atwood定律“凡是能用JavaScript寫出來的應(yīng)用,最終都會用JavaScript來寫”的正確性。追本溯源,這與ECMAScript的發(fā)展功不可沒。
然而,ECMAScript的發(fā)展并非一帆風(fēng)順。
1999年末,ECMA-262第3版[1]正式定稿,在之后的五六年中,幾乎看不到標(biāo)準(zhǔn)的任何新進(jìn)展。直到2005年左右,隨著Google在多個重交互的應(yīng)用中普及Ajax,開發(fā)者們逐漸接受這項(xiàng)新技術(shù)并逐步恢復(fù)對JavaScript的關(guān)注。于是,JavaScript創(chuàng)始人BrendanEich緊鑼密鼓地籌劃ECMAScript4標(biāo)準(zhǔn),直到2007年,耗時(shí)兩年的ECMAScript4標(biāo)準(zhǔn)擴(kuò)充工作在JeffDyer看來已經(jīng)達(dá)到ECMAScript3的兩倍[2],Brendan遂撰文[3]進(jìn)一步澄清與解釋。
DouglasCrockford認(rèn)為這是一種過度復(fù)雜的稅負(fù)[4],并聯(lián)合微軟起草ECMAScript3.1提案,同時(shí),微軟也在TC-39會議中正式反對ES4中的部分標(biāo)準(zhǔn)。沖突過后,占據(jù)輿論優(yōu)勢的ECMAScript3.1于2009年作為ES5正式發(fā)布[5]。
ECMAScript4并未就此消亡。委員會全體成員將ECMAScript3.1與ECMAScript4中的精華保留,作為ECMAScriptHarmony(取和諧之意),它轉(zhuǎn)而成為委員會的下一個目標(biāo)ECMAScript6,并于2015年6月正式定稿,最終被命名為ECMAScript2015。委員會一改往日冗長的議程,約定每年必出一版,通常以當(dāng)年年份命名。截至此書翻譯完畢,ECMAScript2016也于2016年6月正式定稿[6],最新標(biāo)準(zhǔn)尚在進(jìn)程中[7]。
《UnderstandingECMAScript6》一書是作者NicholasC.Zakas在GitHub開源社區(qū)[8]撰寫而成。作為標(biāo)準(zhǔn)的轉(zhuǎn)述者,存在部分理解誤區(qū)合情合理,本譯作基于NoStarchPress出版社于2016年8月出版的首印版,適當(dāng)參考GitHub中的討論集結(jié)而成。
在本書翻譯結(jié)束之際,感慨萬千。首先感謝裕波,是他的引薦讓我有機(jī)會翻譯本書。特別感謝李松峰老師、Hax老師與克軍老師的不吝賜教,幫助我審校翻譯內(nèi)容。還要感謝博文視點(diǎn)的俠少(張春雨編輯),他高標(biāo)準(zhǔn)、嚴(yán)要求的專業(yè)態(tài)度時(shí)刻鞭策我前行。
感謝就職于騰訊的時(shí)光,帶我入行的導(dǎo)師張坤、為我解答所有疑惑的Leader陳恕勝、共同學(xué)習(xí)成長的兄弟陳煒鑫及其他伙伴,你們一絲不茍的態(tài)度不斷磨練我的心性。
最后,特別要感謝我的母親楊虹女士,每當(dāng)我不堪于兼顧工作與翻譯的時(shí)候,總是您的鼓勵點(diǎn)亮我前進(jìn)的道路。
在本書的翻譯過程中我力求還原作者本意,但限于時(shí)間與水平,翻譯不當(dāng)之處在所難免,還敬請各位讀者不吝賜教,我也會及時(shí)與出版社同步以備再版時(shí)進(jìn)行修正,或以勘誤的形式公布。如您有任何想法與建議,歡迎寫信至我的郵箱:lenville@gmail.com。
[1]https://www.ecma-international.org/publications/files/ECMA-ST-ARCH/ECMA-262,3rdedition,December1999.pdf
[2]https://mail.mozilla.org/pipermail/es-discuss/2007-October/001442.html
[3]https://brendaneich.com/2007/11/es4-news-and-opinion/
[4]https://mail.mozilla.org/pipermail/es-discuss/2008-March/002529.html
[5]http://www.ecma-international.org/publications/files/ECMA-ST-ARCH/ECMA-2625theditionDecember2009.pdf
[6]https://www.ecma-international.org/ecma-262/7.0/index.html
[7]https://tc39.github.io/ecma262/
[8]https://github.com/nzakas/understandinges6
序
ECMAScript6如暴風(fēng)雨般驟臨世界,人們期待已久而它卻突然出現(xiàn),傳播之快始料未及。每個人都與ECMAScript6有著一段不同的故事,以下是我的故事。
2013年,我還在一家創(chuàng)業(yè)公司工作,正在從iOS轉(zhuǎn)向Web研發(fā),之后我參加了JavaScript開源社區(qū)并共同創(chuàng)建了Redux。當(dāng)時(shí)我正在努力學(xué)習(xí)Web開發(fā),而且我非常害怕,我的團(tuán)隊(duì)必須在短短幾個月的時(shí)間內(nèi)將我們的產(chǎn)品用JavaScript重構(gòu)為Web版。
起初我認(rèn)為用JavaScript編寫大型軟件的想法很可笑,但是一名團(tuán)隊(duì)成員說服了我,他說JavaScript不是一門玩具語言。我同意撇開成見試一試,于是打開MDN和StackOverflow首次深入學(xué)習(xí)JavaScript。我對這門簡約的語言著了迷,我的同事還教我如何使用工具,例如代碼整理工具(linter)和代碼合并工具(bundler)[譯者注:代碼壓縮工具(minifier)對于生產(chǎn)力和性能來說也至關(guān)重要。]。在這幾個星期里我恍然大悟,原來我如此喜歡編寫JavaScript代碼。
但沒有一門語言是完美的,由于使用過其他語言,我非常希望JavaScript也可以頻繁更新,但在這10年間,ECMAScript5是唯一的重大更新,它只實(shí)現(xiàn)了一小部分特性,完全支持瀏覽器需要數(shù)10年的時(shí)間。彼時(shí),即將到來的代號為Harmony的ECMAScript6(ES6)規(guī)范尚未完成,遙遙無期!耙苍S在10年內(nèi)我能夠?qū)懸恍〦CMAScript6代碼吧!蔽蚁。
一些實(shí)驗(yàn)性的“轉(zhuǎn)譯器(Transpiler)”,如谷歌的Traceur,可以將代碼從ECMAScript6轉(zhuǎn)換成ECMAScript5。它們大多功能非常有限,或難以插入現(xiàn)有的JavaScript構(gòu)建管道。但是,隨后出現(xiàn)的新型轉(zhuǎn)譯器6to5改變了一切。它易于安裝,可以很好地集成在現(xiàn)有的工具中,生成的代碼可讀,于是其像野火般蔓延開來。6to5現(xiàn)在被稱作Babel,在標(biāo)準(zhǔn)定稿前就開始為主流受眾提供ECMAScript6的特性。幾個月以來,ECMAScript6無處不在。
出于各種原因,ECMAScript6已經(jīng)把社區(qū)割裂開來。正如本書所講,在許多主流瀏覽器中ECMAScript6仍未完全實(shí)現(xiàn)。當(dāng)你學(xué)習(xí)這門語言時(shí),不得不進(jìn)行的構(gòu)建步驟足以使人退縮。一些庫的文檔和示例中有ECMAScript6的代碼,你可能想知道這些庫是否可以在ECMAScript5環(huán)境中使用。這令人感到困惑,由于這門語言之前幾乎從未改變過,因此許多人對于新特性的加入并沒有十分期待,而有一部分人在焦急地等待新功能的到來,并希望所有的這些新功能能放在一起使用—在某些情況下,甚至為了使用而使用,不管是否必要。
正當(dāng)我對JavaScript的使用逐漸熟練時(shí),我感覺再往前走很困難,我不得不學(xué)習(xí)一門新的語言。那幾個月的時(shí)間里我感到很糟糕。最后在圣誕節(jié)前夕,我開始閱讀本書的草稿,我簡直愛不釋手,在凌晨3點(diǎn),當(dāng)參加聚會的每一位成員都已熟睡,而我卻理解了ECMAScript6!
Nicholas是一位非常有天賦的老師。他以直截了當(dāng)?shù)姆绞絺鬟_(dá)深刻的細(xì)節(jié),讓你能夠理解所有這些知識。除了本書之外,他也因創(chuàng)建ESLint而出名,這是一個被下載了數(shù)百萬次的JavaScript代碼分析器。
Nicholas對JavaScript的了解程度很少有人能夠企及,所以不要錯過吸取新知識的機(jī)會。閱讀本書,你將對掌握ECMAScript6充滿信心。
DanAbramov
React核心團(tuán)隊(duì)成員及Redux的創(chuàng)造者
前言
JavaScript核心的語言特性是在標(biāo)準(zhǔn)ECMA-262中被定義的。該標(biāo)準(zhǔn)中定義的語言被稱作ECMAScript,它是JavaScript的子集。在瀏覽器與Node.js環(huán)境中通過附加的對象和方法可添加更多新功能,而JavaScript的核心依然保持ECMAScript的定義。總的來說,ECMA-262標(biāo)準(zhǔn)的持續(xù)發(fā)展對于JavaScript的成功功不可沒。ECMAScript6是JavaScript最新的重大更新,本書將為你講解其中的改動。
ECMAScript6之路
2007年,JavaScript走向了發(fā)展中的轉(zhuǎn)折點(diǎn),逐漸興起的Ajax開創(chuàng)了動態(tài)Web應(yīng)用的新時(shí)代,而自1999年第三版ECMA-262發(fā)布以來,JavaScript卻沒有絲毫改變。當(dāng)時(shí),負(fù)責(zé)推動ECMAScript語言發(fā)展的TC-39委員會將大量規(guī)范草案整合在了ECMAScript4中,新增的語言特性涉足甚廣,包括:模塊、類、類繼承、私有對象成員、可選類型注釋及眾多其他的特性。
然而,TC-39組織內(nèi)部對ECMAScript4的動議草案產(chǎn)生了巨大分歧,部分成員認(rèn)為不應(yīng)該一次性在第四版標(biāo)準(zhǔn)中加入過多的新功能,而來自雅虎、谷歌和微軟的技術(shù)負(fù)責(zé)人則共同商討并提交了一份“ECMAScript3.1”草案作為下一代ECMAScript的可選方案,此處的“3.1”意在表明只是對現(xiàn)有標(biāo)準(zhǔn)進(jìn)行小幅的增量修改。
ECMAScript3.1引入的語法變化極少,這一版標(biāo)準(zhǔn)相對而言更專注于優(yōu)化屬性特性,支持原生JSON,以及為已有對象增添新的方法。委員會曾經(jīng)嘗試融合ECMAScript3.1與ECMAScript4,但由于對峙雙方對語言未來的發(fā)展方向分歧過大,最后以失敗告終。
到了2008年,JavaScript創(chuàng)始人BrendanEich宣布TC-39委員會將合力推進(jìn)ECMAScript3.1的標(biāo)準(zhǔn)化工作。他們選擇將ECMAScript4中提出的大部分針對語法及特性的改動暫時(shí)擱置,到下一個版本ECMAScript的標(biāo)準(zhǔn)化工作完成之后,委員會全體成員再努力融合ECMAScript3.1和4中的精華,他們還給這個版本起了一個昵稱—ECMAScriptHarmony(取和諧之意)。
經(jīng)過標(biāo)準(zhǔn)化的ECMAScript3.1最終作為ECMA-262第五版正式發(fā)布,它同時(shí)也被稱為ECMAScript5。委員會表示他們永不發(fā)布第四版,以避免與從未面世的“ECMAScript4”產(chǎn)生命名沖突;贓CMAScriptHarmony的工作隨后陸續(xù)展開,繼承了精華的ECMAScript6將成為繼ECMAScript5之后發(fā)布的首個新標(biāo)準(zhǔn)。
ECMAScript6標(biāo)準(zhǔn)的特性已于2015年全部完成,并被正式命名為“ECMAScript2015”(由于開發(fā)者們對ECMAScript6更為熟悉,因此本書將繼續(xù)沿用此稱謂)。新標(biāo)準(zhǔn)的變化俯拾即是,大到全新的對象和模式、大幅的語法改動,小到為已有對象擴(kuò)充新的方法。更令人激動的是,ECMAScript6中點(diǎn)滴的變化全都致力于解決開發(fā)者實(shí)際工作中遇到的問題。
關(guān)于本書
深入理解ECMAScript6的特性對于所有JavaScript開發(fā)人員來說至關(guān)重要,在可預(yù)見的未來,ECMAScript6中引入的語言特性將構(gòu)成構(gòu)建JavaScript應(yīng)用程序的基礎(chǔ)。這也是本書的初衷,筆者希望你通過閱讀本書來了解ECMAScript6的新特性,并在需要時(shí)隨時(shí)能夠予以使用。
瀏覽器與Node.js中的兼容性
開發(fā)者們正積極地為Web瀏覽器及Node.js這些JavaScript的宿主環(huán)境添加ECMAScript6的新功能。本書只關(guān)注規(guī)范中定義的正確行為,不會對比每種實(shí)現(xiàn)間的差異。如此一來,讀者所使用的JavaScript環(huán)境有可能與本書中描述的不一致。
本書的目標(biāo)讀者
本書是專門為熟悉JavaScript和ECMAScript5的讀者準(zhǔn)備的指南,幫助大家理解ECMAScript5和6之間的差異。對ECMAScript6早已熟稔于心的讀者不必繼續(xù)閱讀下去。本書特別適合想了解語言未來特性的JavaScript中高級開發(fā)者,無論你的工作環(huán)境是Node.js還是Web瀏覽器,本書都非常適合你。
本書不適合從未寫過JavaScript代碼的初學(xué)者,讀者們需要對這門語言的基礎(chǔ)知識有一定的理解,這樣才能發(fā)揮本書的最大效用。
本書概覽
本書中的每一個章節(jié)與附錄都涵蓋有ECMAScript6的不同方面,許多章節(jié)一開始都會討論ECMAScript6中新變化的來龍去脈,以及這些改動試圖解決的問題。所有章節(jié)都包含代碼示例來幫助你學(xué)習(xí)新的語法及概念。
第1章塊級作用域綁定討論var在塊級作用域中的替代方案—let和const。
第2章字符串和正則表達(dá)式詳盡介紹字符串模板,以及新增的操作與檢查字符串的功能。
第3章函數(shù)討論函數(shù)的多處改動,包括箭頭函數(shù)(ArrowFunction)、默認(rèn)參數(shù)(DefaultParameters)、不定參數(shù)(RestParameters)等。
第4章擴(kuò)展對象的功能性解讀對象創(chuàng)建、修改及使用方面的改動,包括對象字面量語法的變化、新的反射方法等。
第5章解構(gòu):使數(shù)據(jù)訪問更便捷介紹一種通過簡明的語法分解對象和數(shù)組的方法—對象和數(shù)組解構(gòu)。
第6章Symbol和Symbol屬性介紹定義屬性的新途徑—Symbol。Symbol是一種新的原始類型,可用于創(chuàng)建外部無法直接訪問的對象屬性和方法。
第7章Set集合與Map集合詳述四種新的集合類型:Set、WeakSet、Map及WeakMap。這些類型為數(shù)組增添了新的語義、去重機(jī)制,以及專門為JavaScript設(shè)計(jì)的內(nèi)存管理機(jī)制,極大地?cái)U(kuò)展了數(shù)組的實(shí)用性。
第8章迭代器(Iterator)和生成器(Generator)這兩個全新的功能可以協(xié)助你更有效地處理集合數(shù)據(jù),在早期版本的JavaScript中無法實(shí)現(xiàn)這樣的功能。
第9章JavaScript中的類介紹JavaScript中首次正式加入的類概念。接觸過其他語言的開發(fā)者通常會對JavaScript的語法感到困惑,新增的類語法使JavaScript變得更易上手,而且對熱衷于JavaScript的開發(fā)者來說新的語法變得更加簡潔。
第10章改進(jìn)數(shù)組的功能詳述針對原生數(shù)組進(jìn)行的改動,以及這些有趣的變化為開發(fā)者所帶來的新體驗(yàn)。
第11章Promise與異步編程介紹語言的新成員—Promise。它是草根群體不斷努力的結(jié)晶,由于各大JavaScript庫的鼎立支持,這一功能逐漸被廣大開發(fā)者所接受。ECMAScript6正式將Promise納入標(biāo)準(zhǔn)并為其提供可用的Polyfill。
第12章代理(Proxy)和反射(Reflection)API介紹正式加入JavaScript的反射API和新的代理對象,開發(fā)者可以通過代理對象攔截每一個在對象中執(zhí)行的操作,代理也賦予了開發(fā)者空前的對象控制權(quán),同樣也為定義新的交互模式帶來無限可能。
第13章用模塊封裝代碼詳述JavaScript的官方模塊風(fēng)格。加入這一定義旨在代替過去幾年中出現(xiàn)過的許多非正式的模塊定義風(fēng)格。
附錄AECMAScript6中較小的改動涵蓋了ECMAScript6中實(shí)現(xiàn)的其他改動,它們與每一章所涉及的主題關(guān)系不大,一般很少使用這些功能。
附錄B了解ECMAScript7(2016)描述了在ECMAScript7中實(shí)現(xiàn)的三個附加功能,它們在近期的影響力不會像ECMAScript6一樣大。
排版約定
本書使用以下的排版約定:
等寬字體代碼塊表示較長的代碼示例,如下所示:
functiondoSomething(){
//empty
}
在代碼塊中,console.log()語句右側(cè)的注釋表示在瀏覽器或Node.js控制臺中顯示的代碼執(zhí)行結(jié)果,例如:
console.log("Hi");//"Hi"
如果代碼塊中的某行代碼引發(fā)錯誤,也會在代碼的右側(cè)指示:
doSomething();//拋出錯誤
幫助與支持
如果你在閱讀本書時(shí)有任何疑問,請發(fā)送郵件至我的郵件列表,地址為http://groups.google.com/group/zakasbooks。
Nicholas C. Zakas自2000年以來一直致力于Web應(yīng)用程序的開發(fā),重點(diǎn)關(guān)注前端開發(fā),并以寫作和講述前沿佳實(shí)踐而聞名。他曾于雅虎主頁任職5年有余,他也是多本書的作者,其中包括The Principles of Object-Oriented JavaScript(No Starch Press出版社)和Professional JavaScript for Web Developers(Wrox出版社)。
關(guān)于技術(shù)評審
Juriy Zaytsev(在網(wǎng)上以kangax著稱)是紐約的一位前端網(wǎng)站開發(fā)人員。自2007年以來,他一直在探索JavaScript的怪異特性并撰寫相關(guān)文章。Juriy為多個開源項(xiàng)目做出過貢獻(xiàn),其中包括Prototype.js和其他的熱門項(xiàng)目,如他自己的Fabric.js。他是按需定制打印服務(wù)printio.ru的共同創(chuàng)始人,目前任職于Facebook。
第1章 塊級作用域綁定 1
var聲明及變量提升(Hoisting)機(jī)制 1
塊級聲明 3
-- let聲明 3
-- 禁止重聲明 4
-- const聲明 4
-- 臨時(shí)死區(qū)(Temporal Dead Zone) 6
循環(huán)中的塊作用域綁定 7
-- 循環(huán)中的函數(shù) 8
-- 循環(huán)中的let聲明 9
-- 循環(huán)中的const聲明 10
全局塊作用域綁定 12
塊級綁定最佳實(shí)踐的進(jìn)化 13
小結(jié) 13
第2章 字符串和正則表達(dá)式 14
更好的Unicode支持 14
-- UTF-16碼位 15
-- codePointAt()方法 16
-- String.fromCodePoint()方法 17
-- normalize()方法 17
-- 正則表達(dá)式u修飾符 19
其他字符串變更 21
-- 字符串中的子串識別 21
-- repeat()方法 22
其他正則表達(dá)式語法變更 23
-- 正則表達(dá)式y(tǒng)修飾符 23
-- 正則表達(dá)式的復(fù)制 26
-- flags屬性 27
模板字面量 28
-- 基礎(chǔ)語法 28
-- 多行字符串 29
-- 字符串占位符 31
-- 標(biāo)簽?zāi)0?32
小結(jié) 36
第3章 函數(shù) 37
函數(shù)形參的默認(rèn)值 37
-- 在ECMAScript 5中模擬默認(rèn)參數(shù) 38
-- ECMAScript 6中的默認(rèn)參數(shù)值 38
-- 默認(rèn)參數(shù)值對arguments對象的影響 40
-- 默認(rèn)參數(shù)表達(dá)式 42
-- 默認(rèn)參數(shù)的臨時(shí)死區(qū) 44
處理無命名參數(shù) 46
-- ECMAScript 5中的無命名參數(shù) 46
-- 不定參數(shù) 47
增強(qiáng)的Function構(gòu)造函數(shù) 49
展開運(yùn)算符 50
name屬性 52
-- 如何選擇合適的名稱 52
-- name屬性的特殊情況 52
明確函數(shù)的多重用途 54
-- 在ECMAScript 5中判斷函數(shù)被調(diào)用的方法 54
-- 元屬性(Metaproperty)new.target 55
塊級函數(shù) 57
-- 塊級函數(shù)的使用場景 58
-- 非嚴(yán)格模式下的塊級函數(shù) 58
箭頭函數(shù) 59
-- 箭頭函數(shù)語法 60
-- 創(chuàng)建立即執(zhí)行函數(shù)表達(dá)式 62
-- 箭頭函數(shù)沒有this綁定 63
-- 箭頭函數(shù)和數(shù)組 65
-- 箭頭函數(shù)沒有arguments綁定 66
-- 箭頭函數(shù)的辨識方法 66
尾調(diào)用優(yōu)化 67
-- ECMAScript 6中的尾調(diào)用優(yōu)化 68
-- 如何利用尾調(diào)用優(yōu)化 69
小結(jié) 71
第4章 擴(kuò)展對象的功能性 72
對象類別 72
對象字面量語法擴(kuò)展 73
-- 屬性初始值的簡寫 73
-- 對象方法的簡寫語法 74
-- 可計(jì)算屬性名(Computed Property Name) 75
新增方法 76
-- Object.is()方法 76
-- Object.assign()方法 77
重復(fù)的對象字面量屬性 80
自有屬性枚舉順序 81
增強(qiáng)對象原型 82
-- 改變對象的原型 82
-- 簡化原型訪問的Super引用 83
正式的方法定義 86
小結(jié) 88
第5章 解構(gòu):使數(shù)據(jù)訪問更便捷 89
為何使用解構(gòu)功能 89
對象解構(gòu) 90
-- 解構(gòu)賦值 91
-- 默認(rèn)值 92
-- 為非同名局部變量賦值 93
-- 嵌套對象解構(gòu) 94
數(shù)組解構(gòu) 96
-- 解構(gòu)賦值 97
-- 默認(rèn)值 99
-- 嵌套數(shù)組解構(gòu) 99
-- 不定元素 99
混合解構(gòu) 101
解構(gòu)參數(shù) 102
-- 必須傳值的解構(gòu)參數(shù) 103
-- 解構(gòu)參數(shù)的默認(rèn)值 104
小結(jié) 106
第6章 Symbol和Symbol屬性 107
創(chuàng)建Symbol 107
Symbol的使用方法 109
Symbol共享體系 110
Symbol與類型強(qiáng)制轉(zhuǎn)換 112
Symbol屬性檢索 112
通過well-known Symbol暴露內(nèi)部操作 113
-- Symbol.hasInstance方法 114
-- Symbol.isConcatSpreadable屬性 116
-- Symbol.match、Symbol.replace、Symbol.search和Symbol.split屬性 118
-- Symbol.toPrimitive方法 120
-- Symbol.toStringTag屬性 122
-- Symbol.unscopables屬性 125
小結(jié) 127
第7章 Set集合與Map集合 128
ECMAScript 5中的Set集合與Map集合 129
該解決方案的一些問題 129
ECMAScript 6中的Set集合 131
-- 創(chuàng)建Set集合并添加元素 131
-- 移除元素 133
-- Set集合的forEach()方法 133
-- 將Set集合轉(zhuǎn)換為數(shù)組 136
-- Weak Set集合 136
ECMAScript 6中的Map集合 139
-- Map集合支持的方法 140
-- Map集合的初始化方法 141
-- Map集合的forEach()方法 142
-- Weak Map集合 143
小結(jié) 147
第8章 迭代器(Iterator)和生成器(Generator) 149
循環(huán)語句的問題 149
什么是迭代器 150
什么是生成器 151
-- 生成器函數(shù)表達(dá)式 153
-- 生成器對象的方法 154
可迭代對象和for-of循環(huán) 155
-- 訪問默認(rèn)迭代器 156
-- 創(chuàng)建可迭代對象 157
內(nèi)建迭代器 158
-- 集合對象迭代器 158
-- 字符串迭代器 163
-- NodeList迭代器 164
展開運(yùn)算符與非數(shù)組可迭代對象 165
高級迭代器功能 166
-- 給迭代器傳遞參數(shù) 166
-- 在迭代器中拋出錯誤 168
-- 生成器返回語句 170
-- 委托生成器 171
異步任務(wù)執(zhí)行 174
-- 簡單任務(wù)執(zhí)行器 174
-- 向任務(wù)執(zhí)行器傳遞數(shù)據(jù) 176
-- 異步任務(wù)執(zhí)行器 177
小結(jié) 180
第9章 JavaScript中的類 181
ECMAScript 5中的近類結(jié)構(gòu) 181
類的聲明 182
-- 基本的類聲明語法 182
-- 為何使用類語法 184
類表達(dá)式 186
-- 基本的類表達(dá)式語法 186
-- 命名類表達(dá)式 187
作為一等公民的類 189
訪問器屬性 190
可計(jì)算成員名稱 192
生成器方法 193
靜態(tài)成員 195
繼承與派生類 196
-- 類方法遮蔽 199
-- 靜態(tài)成員繼承 199
-- 派生自表達(dá)式的類 200
-- 內(nèi)建對象的繼承 203
-- Symbol.species屬性 205
在類的構(gòu)造函數(shù)中使用new.target 208
小結(jié) 210
第10章 改進(jìn)的數(shù)組功能 211
創(chuàng)建數(shù)組 211
-- Array.of()方法 212
-- Array.from()方法 213
為所有數(shù)組添加的新方法 216
-- find()方法和findIndex()方法 217
-- fill()方法 217
-- copyWithin()方法 218
定型數(shù)組 219
-- 數(shù)值數(shù)據(jù)類型 220
-- 數(shù)組緩沖區(qū) 221
-- 通過視圖操作數(shù)組緩沖區(qū) 221
定型數(shù)組與普通數(shù)組的相似之處 228
-- 通用方法 229
-- 相同的迭代器 230
-- of()方法和from()方法 230
定型數(shù)組與普通數(shù)組的差別 231
-- 行為差異 231
-- 缺失的方法 232
-- 附加方法 233
小結(jié) 234
第11章 Promise與異步編程 235
異步編程的背景知識 235
-- 事件模型 236
-- 回調(diào)模式 236
Promise的基礎(chǔ)知識 239
-- Promise的生命周期 239
-- 創(chuàng)建未完成的Promise 242
-- 創(chuàng)建已處理的Promise 244
-- 執(zhí)行器錯誤 247
全局的Promise拒絕處理 248
Node.js環(huán)境的拒絕處理 248
瀏覽器環(huán)境的拒絕處理 251
串聯(lián)Promise 253
-- 捕獲錯誤 254
-- Promise鏈的返回值 255
-- 在Promise鏈中返回Promise 256
響應(yīng)多個Promise 259
-- Promise.all()方法 259
-- Promise.race()方法 260
自Promise繼承 262
基于Promise的異步任務(wù)執(zhí)行 263
小結(jié) 267
第12章 代理(Proxy)和反射(Reflection)API 269
數(shù)組問題 269
代理和反射 270
創(chuàng)建一個簡單的代理 271
使用set陷阱驗(yàn)證屬性 272
用get陷阱驗(yàn)證對象結(jié)構(gòu)(Object Shape) 274
使用has陷阱隱藏已有屬性 275
用deleteProperty陷阱防止刪除屬性 277
原型代理陷阱 279
-- 原型代理陷阱的運(yùn)行機(jī)制 279
-- 為什么有兩組方法 281
對象可擴(kuò)展性陷阱 282
-- 兩個基礎(chǔ)示例 283
-- 重復(fù)的可擴(kuò)展性方法 284
屬性描述符陷阱 285
-- 給Object.defineProperty()添加限制 286
-- 描述符對象限制 287
-- 重復(fù)的描述符方法 288
ownKeys陷阱 290
函數(shù)代理中的apply和construct陷阱 291
-- 驗(yàn)證函數(shù)參數(shù) 292
-- 不用new調(diào)用構(gòu)造函數(shù) 294
-- 覆寫抽象基類構(gòu)造函數(shù) 296
-- 可調(diào)用的類構(gòu)造函數(shù) 297
可撤銷代理 298
解決數(shù)組問題 299
-- 檢測數(shù)組索引 300
-- 添加新元素時(shí)增加length的值 300
-- 減少length的值來刪除元素 302
-- 實(shí)現(xiàn)MyArray類 304
將代理用作原型 307
-- 在原型上使用get陷阱 307
-- 在原型上使用set陷阱 308
-- 在原型上使用has陷阱 309
-- 將代理用作類的原型 310
小結(jié) 314
第13章 用模塊封裝代碼 315
什么是模塊 315
導(dǎo)出的基本語法 316
導(dǎo)入的基本語法 317
-- 導(dǎo)入單個綁定 318
-- 導(dǎo)入多個綁定 318
-- 導(dǎo)入整個模塊 318
-- 導(dǎo)入綁定的一個微妙怪異之處 320
導(dǎo)出和導(dǎo)入時(shí)重命名 320
模塊的默認(rèn)值 321
-- 導(dǎo)出默認(rèn)值 321
-- 導(dǎo)入默認(rèn)值 322
重新導(dǎo)出一個綁定 323
無綁定導(dǎo)入 324
加載模塊 325
-- 在Web瀏覽器中使用模塊 325
-- 瀏覽器模塊說明符解析 329
小結(jié) 330
附錄A ECMAScript 6中較小的改動 331
附錄B 了解ECMAScript 7(2016) 337
索引 343
你還可能感興趣
我要評論
|