国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

如何在ES5與ES6環(huán)境下處理函數(shù)默認(rèn)參數(shù)

oliverhuang / 3290人閱讀

摘要:函數(shù)默認(rèn)值是一個(gè)很提高魯棒性的東西就是讓程序更健壯關(guān)于函數(shù)默認(rèn)參數(shù)的描述函數(shù)默認(rèn)參數(shù)允許在沒有值或被傳入時(shí)使用默認(rèn)形參。也就實(shí)現(xiàn)了上邊三元運(yùn)算符的功能。直接使用這種方式,省去了在函數(shù)內(nèi)部進(jìn)行默認(rèn)值的檢查,能夠讓函數(shù)專注的做它應(yīng)該做的事情。

函數(shù)默認(rèn)值是一個(gè)很提高魯棒性的東西(就是讓程序更健壯)
MDN關(guān)于函數(shù)默認(rèn)參數(shù)的描述:函數(shù)默認(rèn)參數(shù)允許在沒有值或undefined被傳入時(shí)使用默認(rèn)形參。
ES5 使用邏輯或||來實(shí)現(xiàn)

眾所周知,在ES5版本中,并沒有提供的直接方法供我們我們處理函數(shù)默認(rèn)值
所以只能夠自己去增強(qiáng)函數(shù)的功能,一般會(huì)這么來做:

function doSomething (name, age) {
  name = name || "default name"
  age  = age  || 18

  console.log(name, age)
}

我們將函數(shù)的兩個(gè)參數(shù)nameage進(jìn)行默認(rèn)值的處理,如果沒有則使用默認(rèn)值。
在執(zhí)行一下函數(shù)后,好像并沒有什么不對(duì):

doSomething()       // default name, 18
doSomething("Niko") // Niko        , 18
doSomething(, 12)   // default name, 12

然而當(dāng)我們執(zhí)行這樣的代碼時(shí),就會(huì)獲得一些超出預(yù)期的結(jié)果:

doSomething("Niko", 0) // Niko, 18

能夠發(fā)現(xiàn),對(duì)于參數(shù)0,我們上邊的默認(rèn)參數(shù)實(shí)現(xiàn)方法是有問題的

就像下邊的四個(gè)表達(dá)式,都會(huì)輸出wrong,這很顯然不能夠滿足上邊MDN關(guān)于函數(shù)默認(rèn)參數(shù)的定義:

console.log(0         || "wrong")
console.log(""        || "wrong")
console.log(null      || "wrong")
console.log(false     || "wrong")
正確的姿勢(shì)

所以,在ES5中正確的默認(rèn)值處理應(yīng)該是這樣:

function doSomething (name, age) {
  if (name === undefined) {
    name = "default name"
  }

  if (age === undefined) {
    age = 18
  }

  console.log(name, age)
}
使用三元運(yùn)算符簡(jiǎn)化操作

或者我們簡(jiǎn)寫成三元運(yùn)算符形式的:

function doSomething (name, age) {
  name = name === undefined ? "default name" : name
  age  = age  === undefined ? 18             : age

  console.log(name, age)
}
使用函數(shù)進(jìn)行封裝

但是如果我們每寫一個(gè)函數(shù),都要重復(fù)的去做這些操作
未免太麻煩了,所以,我們對(duì)這個(gè)邏輯進(jìn)行一個(gè)簡(jiǎn)單的封裝:

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)
}

這樣就很簡(jiǎn)潔的在ES5實(shí)現(xiàn)了函數(shù)默認(rèn)參數(shù)的邏輯

one momre things

關(guān)于上邊的defaultValue函數(shù)實(shí)現(xiàn)方法,我們?cè)诤侠淼氖褂萌躅愋驼Z(yǔ)言的優(yōu)勢(shì)后
可以使用這種方式來省去三元運(yùn)算符的操作:

function defaultValue () {
  return arguments[+(arguments[0] === undefined)]
}

我們知道,arguments表示函數(shù)所有的實(shí)參
我們使用arguments[0]獲取第一個(gè)實(shí)參,然后與undefined進(jìn)行全等比較
在外層將表達(dá)式的結(jié)果轉(zhuǎn)換為Number,然后將這個(gè)值作為下標(biāo)獲取arguments中對(duì)應(yīng)的參數(shù)。
因?yàn)槭怯?b>Boolean值轉(zhuǎn)變而來,所以只會(huì)存在01兩種選項(xiàng)。
也就實(shí)現(xiàn)了上邊三元運(yùn)算符的功能。

ES6

ES6版本的函數(shù)默認(rèn)值基本上就是我們上邊實(shí)現(xiàn)的那種套路了
但是因?yàn)槭窃模詴?huì)有相應(yīng)的新語(yǔ)法,能夠更簡(jiǎn)潔的使用:

function doSomething (name = "default name", age = 18) {
  console.log(name, age)
}

ES6中提供了新的語(yǔ)法,可以讓我們?cè)诤瘮?shù)聲明參數(shù)后邊直接寫= [defaultValue]的這種形式來設(shè)置某個(gè)參數(shù)的默認(rèn)值。
直接使用這種方式,省去了在函數(shù)內(nèi)部進(jìn)行默認(rèn)值的檢查,能夠讓函數(shù)專注的做它應(yīng)該做的事情。

如何針對(duì)某些必填參數(shù)拋出異常

ES6這種新語(yǔ)法能夠讓我們很好的針對(duì)某個(gè)必填參數(shù)進(jìn)行錯(cuò)誤提醒:

function requireParams () {
  throw new Error("required params")
}

function doSomething (name = requireParams(), age = 18) {
  // do something
}

如果name參數(shù)為undefined,就會(huì)觸發(fā)默認(rèn)值規(guī)則
然后調(diào)用requireParams函數(shù),而我們?cè)诤瘮?shù)中直接throw了一個(gè)Error

復(fù)雜結(jié)構(gòu)參數(shù)的默認(rèn)值處理

上邊的處理都是針對(duì)簡(jiǎn)單的基本類型數(shù)據(jù)進(jìn)行處理的,但如果我們有如下的一個(gè)函數(shù):

function init ({id, value}) {}

init({
  id: "tagId",
  value: 1
})

如果在ES5環(huán)境下,針對(duì)這種參數(shù)的默認(rèn)值處理將會(huì)變得無(wú)比復(fù)雜
首先要判斷這一個(gè)參數(shù)是否存在,然后在判斷參數(shù)中的所有key是否存在
而在ES6中,可以這樣來做:

function init ({
  id    = "defaultId",
  value = 1
} = {}) {
  console.log(id, value)
}

init()

首先在解構(gòu)函數(shù)的后邊添加默認(rèn)值= {},然后針對(duì)每一項(xiàng)參數(shù)添加默認(rèn)值,很簡(jiǎn)潔的就實(shí)現(xiàn)了我們的需求。

ES5版本的polyfill代碼在倉(cāng)庫(kù)中的位置:defaultValue
參考資料

MDN

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/94928.html

相關(guān)文章

  • 深入理解ES6筆記(三)函數(shù)

    摘要:主要知識(shí)點(diǎn)有函數(shù)參數(shù)默認(rèn)值剩余參數(shù)擴(kuò)展運(yùn)算符屬性塊級(jí)函數(shù)箭頭函數(shù)以及尾調(diào)用優(yōu)化深入理解筆記目錄函數(shù)的默認(rèn)參數(shù)在中,我們給函數(shù)傳參數(shù),然后在函數(shù)體內(nèi)設(shè)置默認(rèn)值,如下面這種方式。擁有方法的函數(shù)被稱為構(gòu)造器。 主要知識(shí)點(diǎn)有:函數(shù)參數(shù)默認(rèn)值、剩余參數(shù)、擴(kuò)展運(yùn)算符、new.target屬性、塊級(jí)函數(shù)、箭頭函數(shù)以及尾調(diào)用優(yōu)化showImg(https://segmentfault.com/img/...

    aristark 評(píng)論0 收藏0
  • ES6核心特性

    摘要:報(bào)錯(cuò)不報(bào)此外還有個(gè)好處就是簡(jiǎn)化回調(diào)函數(shù)正常函數(shù)寫法箭頭函數(shù)寫法改變指向長(zhǎng)期以來,語(yǔ)言的對(duì)象一直是一個(gè)令人頭痛的問題,在對(duì)象方法中使用,必須非常小心。 前言 ES6 雖提供了許多新特性,但我們實(shí)際工作中用到頻率較高并不多,根據(jù)二八法則,我們應(yīng)該用百分之八十的精力和時(shí)間,好好專研這百分之二十核心特性,將會(huì)收到事半功倍的奇效!寫文章不容易,請(qǐng)大家多多支持與關(guān)注!本文首發(fā)地址GitHub博客(...

    loostudy 評(píng)論0 收藏0
  • ES6核心特性

    摘要:報(bào)錯(cuò)不報(bào)此外還有個(gè)好處就是簡(jiǎn)化回調(diào)函數(shù)正常函數(shù)寫法箭頭函數(shù)寫法改變指向長(zhǎng)期以來,語(yǔ)言的對(duì)象一直是一個(gè)令人頭痛的問題,在對(duì)象方法中使用,必須非常小心。 前言 ES6 雖提供了許多新特性,但我們實(shí)際工作中用到頻率較高并不多,根據(jù)二八法則,我們應(yīng)該用百分之八十的精力和時(shí)間,好好專研這百分之二十核心特性,將會(huì)收到事半功倍的奇效!寫文章不容易,請(qǐng)大家多多支持與關(guān)注!本文首發(fā)地址GitHub博客(...

    _DangJin 評(píng)論0 收藏0
  • es6 函數(shù)的擴(kuò)展

    摘要:我們來看一看官方解釋函數(shù)內(nèi)部的嚴(yán)格模式,同時(shí)適用于函數(shù)體和函數(shù)參數(shù)。 函數(shù)參數(shù)的默認(rèn)值 我們都知道聲明函數(shù)可以設(shè)置形參,但你有沒有想過形參也可以直接設(shè)置默認(rèn)值,我們接下來看看如何去寫 代碼 function f(x,y=2) { return x+y } console.log(f(2)) // 4 上面的小例子只是設(shè)置了一個(gè)y的默認(rèn)值2,然后我們使用這個(gè)函數(shù)的時(shí)候,只傳遞了x...

    hqman 評(píng)論0 收藏0
  • ES6系列---函數(shù)

    摘要:形參默認(rèn)值不再影響對(duì)象當(dāng)使用默認(rèn)參數(shù)值時(shí),對(duì)象的行為與以往有所不同。具有方法的函數(shù)被統(tǒng)稱為構(gòu)造函數(shù)。當(dāng)調(diào)用函數(shù)的方法時(shí),被賦值為新創(chuàng)建對(duì)象實(shí)例如果調(diào)用方法,則的值為。 由于JavaScript開發(fā)者多年的不斷抱怨和呼吁,ES6終于大力度地更新了函數(shù)特性,在ES5基礎(chǔ)上進(jìn)行了許多改進(jìn)。 函數(shù)形參的默認(rèn)值 ES5形參默認(rèn)值的實(shí)現(xiàn) 在ES5中,你很可能通過以下這種方式為函數(shù)賦予默認(rèn)值: fu...

    AJie 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<