函數(shù)-《understanding ECMAScipt6》讀書筆記3

前言

其實這本書已經(jīng)看完很久了榕订。前幾天突然有人在微信群里分享了別人的翻譯版本店茶。如果有些人會覺得這本書英文比較難理解,還是可以去找翻譯版的看一看劫恒。
我還是接著回顧一下知識點吧贩幻。

參數(shù)默認(rèn)值

解決的問題

ES5中我們經(jīng)常要寫出這樣的代碼:

var a = function(timeout,callback){
 timeout= timeout|| 2000;
 callback = callback || function(){};
}

傳統(tǒng)的方式有兩個方面困擾

  • 如果timeout或callback傳入的值是0,"", null等會被默認(rèn)值替代
  • 繁瑣

下面是ES6的寫法:

var a = function(timeout = 2000,callback=function(){}){
}

此時只有傳參進(jìn)來的值是undefined两嘴,才會用默認(rèn)參數(shù)復(fù)制
等同于

timeout = (typeof timeout !== "undefined")? timeout : 2000; 

默認(rèn)參數(shù)帶來的arguments的變化

首先丛楚,假定一個函數(shù)

var a = function(first,second){
//<1>
fist = "c";
second = "d"
//<2>
}
a("a","b");
  1. ES5 非嚴(yán)格模式下
    無論是1處還是在2處
first === arguments[0];
second === arguments[1];
  1. ES5 嚴(yán)格模式
//1處
first === arguments[0];
second === arguments[1];
//2處
first !== arguments[0];
second !== arguments[1];
  1. ES6中默認(rèn)參數(shù)的情況
var a = function(first,second = "a"){
//first === arguments[0]
//second !== arguments[1]
fist = "c";
second = "d"
//first !== arguments[0]
//second !== arguments[1]
}
a("a","b");

默認(rèn)參數(shù)的使用

  1. 不僅可以賦值,還可以使函數(shù)返回值
var getValue = function(a){
  return a;
}
var a = function(first, second = getValue(1)){
}
  1. 由于second 默認(rèn)參數(shù)是后于first解析的,還可以這樣:
var a = function(first = 1, second = getValue(first)){
}

下面是會拋錯的憔辫,因為默認(rèn)參數(shù)相當(dāng)于let聲明鸯檬,是會有TDZ的。

var a = function(first =  = getValue(second), second = 1){
}

rest參數(shù)

某些時候你需要用到rest參數(shù)去簡化函數(shù)的傳參

var a = function(first,...other){
}

需要注意以下兩點:

  • rest參數(shù)必須是參數(shù)的最后一個
var a = function(first,...other,third){ //error
}
  • 不能用在對象字面量set的時候
var a = { 
    set name(...value){//error 
    }
}
//因為對象字面量的參數(shù)只允許有一個

對Function 構(gòu)造函數(shù)的增強

  • 允許使用默認(rèn)參數(shù)螺垢,示例如下:
var a = new Function("first","second = first", "return first + second");
  • 允許使用rest參數(shù)喧务,示例如下:
var a = new Function("...args", "return args[0]");

擴(kuò)散操作符...

擴(kuò)散操作與rest參數(shù)有密切關(guān)系
rest參數(shù):允許把多個獨立的參數(shù)變?yōu)閿?shù)組
擴(kuò)散操作符: 允許把數(shù)組切割成獨立的參數(shù)

使用場景:
需要使用apply調(diào)用的場合;

函數(shù)的name屬性

匿名函數(shù)表達(dá)式的錯誤難以調(diào)試,ES6為所有函數(shù)添加了name屬性枉圃。

  • 函數(shù)聲明和函數(shù)表達(dá)式
function dosomething(){}
//dosomething.name : "dosomething"
var doAnotherthing(){}
//doAnotherthing.name: "doAnotherthing"
  • 其他情況
var dosomething = function dosomethingElse(){}
//dosomething.name : "dosomethingElse";
var person = {
    get firstName(){},
    sayName:function(){}
}
//person.firstName.name: "get firstName";
//person.sayName.name:"sayName";
var dosomething = function(){};
//dosomething.bind().name:"bound dosomething";
//(new Function()).name : "anonymous";

闡明函數(shù)的兩種使用目的

在ES5中功茴,調(diào)用函數(shù)時用new和不用new有兩種不同的結(jié)果

function Person(name){
  this.name = name;
}
//1
var person = new Person("ali");
//2
var notPerson = Person("ali");

比如說,在1調(diào)用的時候孽亲,返回了一個對象賦值給person,并將person.name設(shè)置為ali坎穿;而在2調(diào)用時,并

未返回值返劲,并在global對象上創(chuàng)建了一個name屬性

在ES6中玲昧,使用new則調(diào)用內(nèi)部的[[construct]]方法實現(xiàn)這一效果,不使用new則調(diào)用內(nèi)部的[[call]]方


注篮绿,不是所有的函數(shù)都有這兩個內(nèi)部方法孵延,箭頭函數(shù)就沒有。

new.target

在ES5中如果要判斷函數(shù)是否用new方式調(diào)用亲配,一般用instanceof尘应,較為繁瑣。
ES6增加了new.target

  • 如果通過[[call]]調(diào)用吼虎,則new.target === undefined
  • 如果通過[[construct]]調(diào)用犬钢,則new.targe === 這個類名;
  • 在函數(shù)外使用new.target會拋錯

函數(shù)在塊級作用域內(nèi)狀況

總所周知的一個bug
在ES3及以前,理論上講函數(shù)聲明在塊級作用域會拋錯思灰,但基本上所有的瀏覽器都支持將函數(shù)寫在塊級作

用域內(nèi)玷犹,但實現(xiàn)方式各有差異。
ES5中嚴(yán)格模式下洒疚, 函數(shù)聲明在塊級作用域下會拋錯歹颓。

ES6嚴(yán)格模式下,函數(shù)聲明在塊級作用域的表現(xiàn)如同用let聲明一樣拳亿,只在塊級作用域有效晴股,有TDZ。
ES6非嚴(yán)格模式下肺魁,函數(shù)聲明在塊級作用域的表現(xiàn)如同用var聲明一樣电湘。

箭頭函數(shù)

  • 沒有this,super,arguments,和new.target綁定
  • 不能用new調(diào)用
  • 沒有原型

箭頭函數(shù)的語法

let reflect = value =>value;
//等同于
let reflect = function(value){
    return value;
}
let sum (num1,num2)=>num1+num2;
//等同于
let sum = function(num1,num2){
    return num1+num2;
}
let getName ()=>"ali";
//等同于
let getName = function(){
    return "ali";
}
//等同于
let getName ()=>{
   return "ali";
}



//等同于
let getName ()=> ("ali")

尾遞歸優(yōu)化

ES6針對遞歸函數(shù)進(jìn)行了優(yōu)化鹅经,不過有幾點限制寂呛。

  • 尾遞歸調(diào)用不需要調(diào)用當(dāng)前棧的變量(所以閉包是不行的)
  • 函數(shù)在遞歸調(diào)用返回后不需要有進(jìn)一步的操作
  • 尾遞歸調(diào)用的結(jié)果必須有返回函數(shù)值
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市瘾晃,隨后出現(xiàn)的幾起案子贷痪,更是在濱河造成了極大的恐慌,老刑警劉巖蹦误,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件劫拢,死亡現(xiàn)場離奇詭異肉津,居然都是意外死亡,警方通過查閱死者的電腦和手機舱沧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進(jìn)店門妹沙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人熟吏,你說我怎么就攤上這事距糖。” “怎么了牵寺?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵悍引,是天一觀的道長。 經(jīng)常有香客問我帽氓,道長趣斤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任杏节,我火速辦了婚禮唬渗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘奋渔。我一直安慰自己镊逝,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布嫉鲸。 她就那樣靜靜地躺著撑蒜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪玄渗。 梳的紋絲不亂的頭發(fā)上座菠,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天,我揣著相機與錄音藤树,去河邊找鬼浴滴。 笑死,一個胖子當(dāng)著我的面吹牛岁钓,可吹牛的內(nèi)容都是我干的升略。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼屡限,長吁一口氣:“原來是場噩夢啊……” “哼品嚣!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起钧大,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤翰撑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后啊央,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體眶诈,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡涨醋,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了册养。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片东帅。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖球拦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情帐我,我是刑警寧澤坎炼,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站拦键,受9級特大地震影響谣光,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜芬为,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一萄金、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧媚朦,春花似錦氧敢、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至份氧,卻和暖如春唯袄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蜗帜。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工恋拷, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人厅缺。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓蔬顾,卻偏偏與公主長得像,于是被迫代替她去往敵國和親店归。 傳聞我的和親對象是個殘疾皇子阎抒,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,490評論 2 348

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