国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 19:43:59
文檔

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

如何操作ES5與ES6環境下處理函數默認參數:這次給大家帶來如何操作ES5與ES6環境下處理函數默認參數,操作ES5與ES6環境下處理函數默認參數的注意事項有哪些,下面就是實戰案例,一起來看一下。函數默認值是一個很提高魯棒性的東西(就是讓程序更健壯)MDN關于函數默認參數的描述:函數默認參數允許在沒
推薦度:
導讀如何操作ES5與ES6環境下處理函數默認參數:這次給大家帶來如何操作ES5與ES6環境下處理函數默認參數,操作ES5與ES6環境下處理函數默認參數的注意事項有哪些,下面就是實戰案例,一起來看一下。函數默認值是一個很提高魯棒性的東西(就是讓程序更健壯)MDN關于函數默認參數的描述:函數默認參數允許在沒

這次給大家帶來如何操作ES5與ES6環境下處理函數默認參數,操作ES5與ES6環境下處理函數默認參數的注意事項有哪些,下面就是實戰案例,一起來看一下。

函數默認值是一個很提高魯棒性的東西(就是讓程序更健壯)

MDN關于函數默認參數的描述:函數默認參數允許在沒有值或undefined被傳入時使用默認形參。

ES5

使用邏輯或||來實現

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

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

我們將函數的兩個參數name與age進行默認值的處理,如果沒有則使用默認值。

在執行一下函數后,好像并沒有什么不對:

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值轉變而來,所以只會存在0、1兩種選項。

也就實現了上邊三元運算符的功能。

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

相信看了本文案例你已經掌握了方法,更多精彩請關注Gxl網其它相關文章!

推薦閱讀:

怎樣優化js async函數

如何使用node搭建服務器,寫接口,調接口,跨域

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

如何操作ES5與ES6環境下處理函數默認參數:這次給大家帶來如何操作ES5與ES6環境下處理函數默認參數,操作ES5與ES6環境下處理函數默認參數的注意事項有哪些,下面就是實戰案例,一起來看一下。函數默認值是一個很提高魯棒性的東西(就是讓程序更健壯)MDN關于函數默認參數的描述:函數默認參數允許在沒
推薦度:
標簽: 使用 處理 如何
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲欧美综合网 | 日韩精品一区二区三区国语自制 | 成人精品第一区二区三区 | 欧美日韩精品一区二区在线播放 | 精品久久久久久久久中文字幕 | 欧美国产中文 | 日韩大片免费观看视频播放 | 国产精品视频自拍 | 亚洲免费网站观看视频 | 国产精品视频福利一区二区 | 亚洲欧美视屏 | 国产网站免费观看 | 亚洲欧美日韩精品专区卡通 | 欧美日韩国产码高清综合人成 | 中文字幕一区二区三区在线观看 | 一区二区影视 | 日本一二三区高清 | 亚洲欧美国产精品 | 亚洲国产成人久久综合一 | 日韩一区二区三区在线 | 黄色毛片a| 国产一区三区二区中文在线 | 精品一区二区在线 | 国产自在自线午夜精品视频 | 国产视频最新 | 伊人久久精品一区二区三区 | 欧美性俄罗斯18精品 | 欧美人与禽x0x0牲伦交 | 免费在线观看国产 | 黄大片在线观看 | 中文字幕有码在线播放 | 偷牌自拍 | 亚洲欧美中文日韩综合 | 亚洲一区二区三区四区在线 | 欧美一级网站 | 国产成人久久精品一区二区三区 | 国产成人高清亚洲一区91 | 中文国产成人精品久久一区 | 亚洲一区精品伊人久久 | 亚洲一区日韩一区欧美一区a | 精品日韩一区二区三区 |