ES6的特性有哪些?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
為肅南裕固族自治等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及肅南裕固族自治網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為做網(wǎng)站、網(wǎng)站建設(shè)、肅南裕固族自治網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!ES6(ECMAScript2015)的出現(xiàn),無(wú)疑給前端開(kāi)發(fā)人員帶來(lái)了新的驚喜,它包含了一些很棒的新特性,可以更加方便的實(shí)現(xiàn)很多復(fù)雜的操作,提高開(kāi)發(fā)人員的效率。
以下是ES6排名前十的很好特性列表(排名不分先后):
1.Block-Scoped Constructs Let and Const(塊作用域構(gòu)造Let and Const)
2.Arrow Functions (箭頭函數(shù))in ES6
3.Default Parameters(默認(rèn)參數(shù)) in ES6
4.Template Literals (模板文本)in ES6
5.Multi-line Strings (多行字符串)in ES6
6.Destructuring Assignment (解構(gòu)賦值)in ES6
7.Enhanced Object Literals (增強(qiáng)的對(duì)象文本)in ES6
8.Promises in ES6
9.Classes(類) in ES6
10.Modules(模塊) in ES6
首先回顧一下JavaScript的歷史,不清楚歷史的人,很難理解JavaScript為什么會(huì)這樣發(fā)展。下面就是一個(gè)簡(jiǎn)單的JavaScript發(fā)展時(shí)間軸:
1、1995:JavaScript誕生,它的初始名叫LiveScript。
2、1997:ECMAScript標(biāo)準(zhǔn)確立。
3、1999:ES3出現(xiàn),與此同時(shí)IE5風(fēng)靡一時(shí)。
4、2000–2005: XMLHttpRequest又名AJAX, 在Outlook Web Access (2000)、Oddpost (2002),Gmail (2004)和Google Maps (2005)大受重用。
5、2009: ES5出現(xiàn),(就是我們大多數(shù)人現(xiàn)在使用的)例如foreach,Object.keys,Object.create和JSON標(biāo)準(zhǔn)。
6、2015:ES6/ECMAScript2015出現(xiàn)。
歷史回顧就先到此,現(xiàn)讓我們進(jìn)入正題。
在ES6代碼中,你可能已經(jīng)看到那熟悉的身影l(fā)et。在ES6里let并不是一個(gè)花俏的特性,它是更復(fù)雜的。Let是一種新的變量聲明方式,它允許你把變量作用域控制在塊級(jí)里面。我們用大括號(hào)定義代碼塊,在ES5中,塊級(jí)作用域起不了任何作用:
function calculateTotalAmount (vip) { var amount = 0; if (vip) { var amount = 1; } { // more crazy blocks! var amount = 100; { var amount = 1000; } } return amount; } console.log(calculateTotalAmount(true)); 結(jié)果將返回1000,這真是一個(gè)bug。在ES6中,我們用let限制塊級(jí)作用域。而var是限制函數(shù)作用域。 function calculateTotalAmount (vip) { var amount = 0; // probably should also be let, but you can mix var and let if (vip) { let amount = 1; // first amount is still 0 } { // more crazy blocks! let amount = 100; // first amount is still 0 { let amount = 1000; // first amount is still 0 } } return amount; } console.log(calculateTotalAmount(true));