ES6語(yǔ)法

阮一峰的博客
http://es6.ruanyifeng.com/

一 ES6簡(jiǎn)介

ECMAScript 6.0(以下簡(jiǎn)稱(chēng) ES6)是 JavaScript 語(yǔ)言的下一代標(biāo)準(zhǔn)况既,已經(jīng)在2015年6月正式發(fā)布了。

2011年笑撞,ECMAScript 5.1版發(fā)布后黄伊,就開(kāi)始制定6.0版了站故。
因此,ES6 這個(gè)詞的原意毅舆,
就是指 JavaScript 語(yǔ)言的下一個(gè)版本西篓。

二 檢查瀏覽器是否支持ES6的方法

http://ruanyf.github.io/es-checker

三 語(yǔ)法介紹

(一) let和const的使用
1.1 let 關(guān)鍵字的使用
1.2 let和 var的區(qū)別案例
1.3 ES6的代碼塊作用域
1.4 let 不存在變量的提升定義
1.5 let的暫時(shí)性死區(qū)
1.6 const 關(guān)鍵字的使用
1.7 const定義常量的使用
1.8 const的本質(zhì)
const實(shí)際上保證的,并不是變量的值不得改動(dòng)憋活,而是變量指向的那個(gè)內(nèi)存地址不得改動(dòng)岂津。對(duì)于簡(jiǎn)單類(lèi)型的數(shù)據(jù)(數(shù)值、字符串悦即、布爾值)吮成,值就保存在變量指向的那個(gè)內(nèi)存地址,因此等同于常量辜梳。但對(duì)于復(fù)合類(lèi)型的數(shù)據(jù)(主要是對(duì)象和數(shù)組)粱甫,變量指向的內(nèi)存地址,保存的只是一個(gè)指針作瞄,const只能保證這個(gè)指針是固定的茶宵,至于它指向的數(shù)據(jù)結(jié)構(gòu)是不是可變的,就完全不能控制了宗挥。因此乌庶,將一個(gè)對(duì)象聲明為常量必須非常小心。
2.0 ES6 聲明變量的六種方法
2.1 ES6 的頂層對(duì)象的屬性
注意let和const變量 不添加到window中

(二) 變量的解構(gòu)賦值
1.1 數(shù)組的解構(gòu)
let [a,b] = [100,200];
1.2 對(duì)象的解構(gòu)
注意: 對(duì)象的解構(gòu)沒(méi)有順序
let { bar, foo } = { foo: "aaa", bar: "bbb" };
1.3 數(shù)值和布爾值的解構(gòu)賦值
1.4 函數(shù)參數(shù)的解構(gòu)賦值 (函數(shù)會(huì)說(shuō)明)
1.5 圓括號(hào)問(wèn)題

(三) 字符串?dāng)U展
1.1 字符的 Unicode 表示法

百度搜索:漢字字符編碼
http://www.mytju.com/classCode/tools/encode_gb2312.asp
http://tool.chinaz.com/Tools/Unicode.aspx

1.2 codePointAt()
1.3 String.fromCodePoint()
1.4 字符串的遍歷器接口
for...of的使用 和for...in的區(qū)別
1.5 charAt方法 ES5新增的方法
1.6 includes(), startsWith(), endsWith()
1.7 repeat()
1.8 模板字符串(重點(diǎn))
// ES6字符串教程中
// 有箭頭函數(shù)的寫(xiě)法和...參數(shù)的寫(xiě)法
1.8.1 字符串模板的來(lái)源是使用+的不方便
'name'+name+"age is"+age
1.8.2 字符串的插值采用${name}的方式實(shí)現(xiàn)
1.8.3 標(biāo)簽?zāi)0?tagged template

            function tag(stringArr, value1, value2){
                // ...
            }

            // 等同于
            function tag(stringArr, ...values){
                // ...
            }

(四) 函數(shù)的擴(kuò)展
1.1 函數(shù)參數(shù)的默認(rèn)值
ES6新添加的函數(shù)默認(rèn)值
1.2 rest參數(shù)
ES6 引入 rest 參數(shù)(形式為"...變量名")契耿,用于獲取函數(shù)的多余參數(shù)瞒大,這樣就不需要使用arguments對(duì)象了
1.3 擴(kuò)展運(yùn)算符
可以看做前面的rest參數(shù)的逆運(yùn)算
擴(kuò)展運(yùn)算符(spread)是三個(gè)點(diǎn)(...)
將一個(gè)數(shù)組轉(zhuǎn)為用逗號(hào)分隔的參數(shù)序列。
注意:三個(gè)點(diǎn)(...)用在不同的地方表示的意義不一樣
1.4 嚴(yán)格模式
1.4.1 從 ES5 開(kāi)始搪桂,函數(shù)內(nèi)部可以設(shè)定為嚴(yán)格模式透敌。
1.4.3 ES2016 做了一點(diǎn)修改,規(guī)定只要函數(shù)參數(shù)使用了默認(rèn)值、解構(gòu)賦值酗电、或者擴(kuò)展運(yùn)算符淌山,那么函數(shù)內(nèi)部就不能顯式設(shè)定為嚴(yán)格模式,否則會(huì)報(bào)錯(cuò)顾瞻。

1.5 name 屬性
1.6 箭頭函數(shù)
1.7 綁定 this

(五) 數(shù)值Number的擴(kuò)展
1.1 二進(jìn)制和八進(jìn)制表示法
1.2 Number.isFinite(), Number.isNaN()
1.3 Number.parseInt(), Number.parseFloat()
1.4 Number.isInteger()

四 Babel介紹使用

1.1 后綴名稱(chēng)為.babelrc文件
添加:
{
"presets": ["env"]
}
1.2 安裝babel的包文件
npm install --save-dev babel-cli babel-preset-env

1.2 運(yùn)行測(cè)試文件01example.js
1.3 babel測(cè)試文件
babel 01example.js
1.4 babel -d 測(cè)試輸出文件
babel 01example.js --out-file 01result.js
或者
babel 01example.js -o 01result.js
1.5 babel 的配置環(huán)境介紹
https://excaliburhan.com/post/babel-preset-and-plugins.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末泼疑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子荷荤,更是在濱河造成了極大的恐慌退渗,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蕴纳,死亡現(xiàn)場(chǎng)離奇詭異会油,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)古毛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門(mén)翻翩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人稻薇,你說(shuō)我怎么就攤上這事嫂冻。” “怎么了塞椎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵桨仿,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我案狠,道長(zhǎng)服傍,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任骂铁,我火速辦了婚禮吹零,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拉庵。我一直安慰自己灿椅,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布名段。 她就那樣靜靜地躺著阱扬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪伸辟。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,185評(píng)論 1 284
  • 那天馍刮,我揣著相機(jī)與錄音信夫,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛静稻,可吹牛的內(nèi)容都是我干的表伦。 我是一名探鬼主播磅摹,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了勺拣?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤垦细,失蹤者是張志新(化名)和其女友劉穎捺典,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體大州,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡续语,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了厦画。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疮茄。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖根暑,靈堂內(nèi)的尸體忽然破棺而出力试,到底是詐尸還是另有隱情,我是刑警寧澤排嫌,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布懂版,位于F島的核電站,受9級(jí)特大地震影響躏率,放射性物質(zhì)發(fā)生泄漏躯畴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一薇芝、第九天 我趴在偏房一處隱蔽的房頂上張望蓬抄。 院中可真熱鬧,春花似錦夯到、人聲如沸嚷缭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)阅爽。三九已至,卻和暖如春荐开,著一層夾襖步出監(jiān)牢的瞬間付翁,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工晃听, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留百侧,地道東北人砰识。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像佣渴,于是被迫代替她去往敵國(guó)和親辫狼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 阮一峰的博客 http://es6.ruanyifeng.com/ 一 ES6簡(jiǎn)介 ECMAScript 6.0(...
    ai搞搞閱讀 1,721評(píng)論 0 0
  • 以下內(nèi)容是我在學(xué)習(xí)和研究ES6時(shí)辛润,對(duì)ES6的特性膨处、重點(diǎn)和注意事項(xiàng)的提取、精練和總結(jié)砂竖,可以做為ES6特性的字典真椿;在本...
    科研者閱讀 3,113評(píng)論 2 9
  • 引用:http://hao.jser.com/archive/10813/?utm_source=tuicool&...
    莊志平閱讀 1,201評(píng)論 1 14
  • ES6帶來(lái)了Javascript新的變化,新的語(yǔ)法特性晦溪,使得之以前版本中需要特性方式才能解決的問(wèn)題一些問(wèn)題得到了簡(jiǎn)...
    Patrick浩閱讀 652評(píng)論 0 1
  • 概念: 1.ECMAScript 6(以下簡(jiǎn)稱(chēng)ES6)是JavaScript語(yǔ)言的下一代標(biāo)準(zhǔn)瀑粥。??????????...
    Sujz閱讀 219評(píng)論 1 2