摘要:函數(shù)默認值是一個很提高魯棒性的東西就是讓程序更健壯關于函數(shù)默認參數(shù)的描述函數(shù)默認參數(shù)允許在沒有值或被傳入時使用默認形參。也就實現(xiàn)了上邊三元運算符的功能。直接使用這種方式,省去了在函數(shù)內部進行默認值的檢查,能夠讓函數(shù)專注的做它應該做的事情。
函數(shù)默認值是一個很提高魯棒性的東西(就是讓程序更健壯)ES5 使用邏輯或||來實現(xiàn)
MDN關于函數(shù)默認參數(shù)的描述:函數(shù)默認參數(shù)允許在沒有值或undefined被傳入時使用默認形參。
眾所周知,在ES5版本中,并沒有提供的直接方法供我們我們處理函數(shù)默認值
所以只能夠自己去增強函數(shù)的功能,一般會這么來做:
function doSomething (name, age) { name = name || "default name" age = age || 18 console.log(name, age) }
我們將函數(shù)的兩個參數(shù)name與age進行默認值的處理,如果沒有則使用默認值。
在執(zhí)行一下函數(shù)后,好像并沒有什么不對:
doSomething() // default name, 18 doSomething("Niko") // Niko , 18 doSomething(, 12) // default name, 12
然而當我們執(zhí)行這樣的代碼時,就會獲得一些超出預期的結果:
doSomething("Niko", 0) // Niko, 18
能夠發(fā)現(xiàn),對于參數(shù)0,我們上邊的默認參數(shù)實現(xiàn)方法是有問題的
就像下邊的四個表達式,都會輸出wrong,這很顯然不能夠滿足上邊MDN關于函數(shù)默認參數(shù)的定義:
console.log(0 || "wrong") console.log("" || "wrong") console.log(null || "wrong") console.log(false || "wrong")正確的姿勢
所以,在ES5中正確的默認值處理應該是這樣:
function doSomething (name, age) { if (name === undefined) { name = "default name" } if (age === undefined) { age = 18 } console.log(name, age) }使用三元運算符簡化操作
或者我們簡寫成三元運算符形式的:
function doSomething (name, age) { name = name === undefined ? "default name" : name age = age === undefined ? 18 : age console.log(name, age) }使用函數(shù)進行封裝
但是如果我們每寫一個函數(shù),都要重復的去做這些操作
未免太麻煩了,所以,我們對這個邏輯進行一個簡單的封裝:
function defaultValue (val, defaultVal) { return val === undefined ? defaultVal : val } function doSomething (name, age) { name = defaultValue(name, "default name") age = defaultValue(age , 18) console.log(name, age) }
這樣就很簡潔的在ES5實現(xiàn)了函數(shù)默認參數(shù)的邏輯
關于上邊的defaultValue函數(shù)實現(xiàn)方法,我們在合理的使用弱類型語言的優(yōu)勢后
可以使用這種方式來省去三元運算符的操作:
function defaultValue () { return arguments[+(arguments[0] === undefined)] }
我們知道,arguments表示函數(shù)所有的實參
我們使用arguments[0]獲取第一個實參,然后與undefined進行全等比較
在外層將表達式的結果轉換為Number,然后將這個值作為下標獲取arguments中對應的參數(shù)。
因為是由Boolean值轉變而來,所以只會存在0、1兩種選項。
也就實現(xiàn)了上邊三元運算符的功能。
ES6版本的函數(shù)默認值基本上就是我們上邊實現(xiàn)的那種套路了
但是因為是原生的,所以會有相應的新語法,能夠更簡潔的使用:
function doSomething (name = "default name", age = 18) { console.log(name, age) }
ES6中提供了新的語法,可以讓我們在函數(shù)聲明參數(shù)后邊直接寫= [defaultValue]的這種形式來設置某個參數(shù)的默認值。
直接使用這種方式,省去了在函數(shù)內部進行默認值的檢查,能夠讓函數(shù)專注的做它應該做的事情。
ES6這種新語法能夠讓我們很好的針對某個必填參數(shù)進行錯誤提醒:
function requireParams () { throw new Error("required params") } function doSomething (name = requireParams(), age = 18) { // do something }
如果name參數(shù)為undefined,就會觸發(fā)默認值規(guī)則
然后調用requireParams函數(shù),而我們在函數(shù)中直接throw了一個Error
上邊的處理都是針對簡單的基本類型數(shù)據(jù)進行處理的,但如果我們有如下的一個函數(shù):
function init ({id, value}) {} init({ id: "tagId", value: 1 })
如果在ES5環(huán)境下,針對這種參數(shù)的默認值處理將會變得無比復雜
首先要判斷這一個參數(shù)是否存在,然后在判斷參數(shù)中的所有key是否存在
而在ES6中,可以這樣來做:
function init ({ id = "defaultId", value = 1 } = {}) { console.log(id, value) } init()
首先在解構函數(shù)的后邊添加默認值= {},然后針對每一項參數(shù)添加默認值,很簡潔的就實現(xiàn)了我們的需求。
ES5版本的polyfill代碼在倉庫中的位置:defaultValue參考資料
MDN
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.hztianpu.com/yun/94928.html
摘要:主要知識點有函數(shù)參數(shù)默認值剩余參數(shù)擴展運算符屬性塊級函數(shù)箭頭函數(shù)以及尾調用優(yōu)化深入理解筆記目錄函數(shù)的默認參數(shù)在中,我們給函數(shù)傳參數(shù),然后在函數(shù)體內設置默認值,如下面這種方式。擁有方法的函數(shù)被稱為構造器。 主要知識點有:函數(shù)參數(shù)默認值、剩余參數(shù)、擴展運算符、new.target屬性、塊級函數(shù)、箭頭函數(shù)以及尾調用優(yōu)化showImg(https://segmentfault.com/img/...
摘要:我們來看一看官方解釋函數(shù)內部的嚴格模式,同時適用于函數(shù)體和函數(shù)參數(shù)。 函數(shù)參數(shù)的默認值 我們都知道聲明函數(shù)可以設置形參,但你有沒有想過形參也可以直接設置默認值,我們接下來看看如何去寫 代碼 function f(x,y=2) { return x+y } console.log(f(2)) // 4 上面的小例子只是設置了一個y的默認值2,然后我們使用這個函數(shù)的時候,只傳遞了x...
摘要:形參默認值不再影響對象當使用默認參數(shù)值時,對象的行為與以往有所不同。具有方法的函數(shù)被統(tǒng)稱為構造函數(shù)。當調用函數(shù)的方法時,被賦值為新創(chuàng)建對象實例如果調用方法,則的值為。 由于JavaScript開發(fā)者多年的不斷抱怨和呼吁,ES6終于大力度地更新了函數(shù)特性,在ES5基礎上進行了許多改進。 函數(shù)形參的默認值 ES5形參默認值的實現(xiàn) 在ES5中,你很可能通過以下這種方式為函數(shù)賦予默認值: fu...
閱讀 2396·2021-11-16 11:51
閱讀 3595·2021-09-26 10:14
閱讀 2042·2021-09-22 15:58
閱讀 1153·2019-08-30 15:52
閱讀 2083·2019-08-30 15:43
閱讀 2682·2019-08-30 13:46
閱讀 983·2019-08-30 13:10
閱讀 1135·2019-08-29 18:32