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

資訊專欄INFORMATION COLUMN

如何在ES5與ES6環境下處理函數默認參數

oliverhuang / 3284人閱讀

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

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

眾所周知,在ES5版本中,并沒有提供的直接方法供我們我們處理函數默認值
所以只能夠自己去增強函數的功能,一般會這么來做:

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

  console.log(name, age)
}

我們將函數的兩個參數nameage進行默認值的處理,如果沒有則使用默認值。
在執行一下函數后,好像并沒有什么不對:

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

然而當我們執行這樣的代碼時,就會獲得一些超出預期的結果:

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

能夠發現,對于參數0,我們上邊的默認參數實現方法是有問題的

就像下邊的四個表達式,都會輸出wrong,這很顯然不能夠滿足上邊MDN關于函數默認參數的定義:

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)
}
使用函數進行封裝

但是如果我們每寫一個函數,都要重復的去做這些操作
未免太麻煩了,所以,我們對這個邏輯進行一個簡單的封裝:

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實現了函數默認參數的邏輯

one momre things

關于上邊的defaultValue函數實現方法,我們在合理的使用弱類型語言的優勢后
可以使用這種方式來省去三元運算符的操作:

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

我們知道,arguments表示函數所有的實參
我們使用arguments[0]獲取第一個實參,然后與undefined進行全等比較
在外層將表達式的結果轉換為Number,然后將這個值作為下標獲取arguments中對應的參數。
因為是由Boolean值轉變而來,所以只會存在01兩種選項。
也就實現了上邊三元運算符的功能。

ES6

ES6版本的函數默認值基本上就是我們上邊實現的那種套路了
但是因為是原生的,所以會有相應的新語法,能夠更簡潔的使用:

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

ES6中提供了新的語法,可以讓我們在函數聲明參數后邊直接寫= [defaultValue]的這種形式來設置某個參數的默認值。
直接使用這種方式,省去了在函數內部進行默認值的檢查,能夠讓函數專注的做它應該做的事情。

如何針對某些必填參數拋出異常

ES6這種新語法能夠讓我們很好的針對某個必填參數進行錯誤提醒:

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

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

如果name參數為undefined,就會觸發默認值規則
然后調用requireParams函數,而我們在函數中直接throw了一個Error

復雜結構參數的默認值處理

上邊的處理都是針對簡單的基本類型數據進行處理的,但如果我們有如下的一個函數:

function init ({id, value}) {}

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

如果在ES5環境下,針對這種參數的默認值處理將會變得無比復雜
首先要判斷這一個參數是否存在,然后在判斷參數中的所有key是否存在
而在ES6中,可以這樣來做:

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

init()

首先在解構函數的后邊添加默認值= {},然后針對每一項參數添加默認值,很簡潔的就實現了我們的需求。

ES5版本的polyfill代碼在倉庫中的位置:defaultValue
參考資料

MDN

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/94928.html

相關文章

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

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

    aristark 評論0 收藏0
  • ES6核心特性

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

    loostudy 評論0 收藏0
  • ES6核心特性

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

    _DangJin 評論0 收藏0
  • es6 函數的擴展

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

    hqman 評論0 收藏0
  • ES6系列---函數

    摘要:形參默認值不再影響對象當使用默認參數值時,對象的行為與以往有所不同。具有方法的函數被統稱為構造函數。當調用函數的方法時,被賦值為新創建對象實例如果調用方法,則的值為。 由于JavaScript開發者多年的不斷抱怨和呼吁,ES6終于大力度地更新了函數特性,在ES5基礎上進行了許多改進。 函數形參的默認值 ES5形參默認值的實現 在ES5中,你很可能通過以下這種方式為函數賦予默認值: fu...

    AJie 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<