的setinterval函数_ES6 极简教程 lt;6gt; 函数扩展
1. 函數(shù)參數(shù)默認值
用法如下
{function test(x, y = 'world') {console.log('默認值', x, y);}test('hello'); // hello worldtest('hello', 'TH'); // hello TH }2. rest 參數(shù)
在不確定參數(shù)個數(shù)的時候,把輸入的參數(shù)都轉(zhuǎn)化為數(shù)組:
注意: rest 參數(shù)后邊不能再放其他參數(shù)了, 否則會報錯
{function test3(...arg) {for (let v of arg) {console.log('rest', v);}}test3(1, 2, 3, 4, 'a'); }// rest 1 // rest 2 // rest 3 // rest 4 // rest a3. 箭頭函數(shù)
引入箭頭函數(shù)有兩個方面的作用:更簡短的函數(shù)并且不綁定this。
3.1用法
(參數(shù)1, 參數(shù)2, …, 參數(shù)N) => { 函數(shù)聲明 }//相當(dāng)于:(參數(shù)1, 參數(shù)2, …, 參數(shù)N) =>{ return 表達式; } (參數(shù)1, 參數(shù)2, …, 參數(shù)N) => 表達式(單一)// 當(dāng)只有一個參數(shù)時,圓括號是可選的: (單一參數(shù)) => {函數(shù)聲明} 單一參數(shù) => {函數(shù)聲明}// 沒有參數(shù)的函數(shù)應(yīng)該寫成一對圓括號。 () => {函數(shù)聲明}3.2 關(guān)于this
箭頭函數(shù)不會創(chuàng)建自己的this,它只會從自己的作用域鏈的上一層繼承this。this會在函數(shù)定義時候就被確定(es5中非箭頭函數(shù)則在運行是才會被確定)
function Person(){this.age = 0;setInterval(() => {this.age++; // |this| 正確地指向 p 實例}, 1000); }var p = new Person();3.3. call apply bind 與箭頭函數(shù)
由于箭頭函數(shù)沒有自己的this指針,通過 call() 或apply() 方法調(diào)用一個函數(shù)時,只能傳遞參數(shù)(不能綁定this),他們的第一個參數(shù)會被忽略。(這種現(xiàn)象對于bind方法同樣成立)。
3.4. 其他
箭頭函數(shù)不能用作構(gòu)造器,和new一起用會拋出錯誤。
箭頭函數(shù)不綁定Arguments 對象。
箭頭函數(shù)沒有prototype屬性。
yield 關(guān)鍵字通常不能在箭頭函數(shù)中使用(除非是嵌套在允許使用的函數(shù)內(nèi))。因此,箭頭函數(shù)不能用作生成器
總結(jié)
以上是生活随笔為你收集整理的的setinterval函数_ES6 极简教程 lt;6gt; 函数扩展的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于圣诞节的来历众说纷纭,有没有准确答案
- 下一篇: oracle中exists连接两个表,I