首頁 > web前端 > js教程 > ECMAScript6函數預設參數_javascript技巧

ECMAScript6函數預設參數_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-05-16 15:55:37
原創
1112 人瀏覽過

語言更新時每一個新增的特性都是從千百萬開發者需求裡提取過來的,規範採用後能減少程式設計師的痛苦,帶來便捷。

我們常常會這麼寫

function calc(x, y) {
  x = x || 0;
  y = y || 0;
  // to do with x, y
  // return x/y
}
登入後複製

簡單說就是x,y提供了一個預設值為0,不傳時x, y以值0來運算。傳了就以實際值計算。

又如定義一個ajax

function ajax(url, async, dataType) {
  async = async !== false
  dataType = dataType || 'JSON'
  // ...
}
登入後複製

自己用原生JS封裝的一個簡易ajax函數,url必填,async和dataType可選,即不填時預設同步請求和返回JSON格式資料。

再如定義一個矩形類別

function Rectangle(width, height) {
  this.width = width || 200;
  this.height = height || 300;
}
登入後複製

new時不傳任何參數,也會建立一個預設寬高為200*300的矩形。

無論是calc,ajax函數還是Rectangle類,我們都需要在函數體內做預設值的處理,如果語言本身處理豈不樂哉? ES6提供了該特性(Default Parameters),以下是用ES6新特性重寫的calc,ajax,Rectangle。

function calc(x=0, y=0) {
  // ...
  console.log(x, y)
}
calc(); // 0 0
calc(1, 4); // 1 4
 
function ajax(url, async=true, dataType="JSON") {
  // ...
  console.log(url, async, dataType)
}
ajax('../user.action'); // ../user.action true JSON
ajax('../user.action', false); // ../user.action false JSON
ajax('../user.action', false, 'XML'); // ../user.action false XML
 
function Rectangle(width=200, height=300) {
  this.width = width;
  this.height = height;
}
var r1 = new Rectangle(); // 200*300的矩形
var r2 = new Rectangle(100); // 100*300的矩形
var r3 = new Rectangle(100, 500); // 100*500矩形
登入後複製

可以看到,ES6把預設值部分從大括號移到了小括號裡,還減少了「||」運算,函數體從此瘦身了。參數預設值嘛,本來就該在定義參數的地方,這樣看起來簡潔了不少。 O(∩_∩)O

預設參數可以定義在任意位置,例如在中間定義一個

function ajax(url, async=true, success) {
  // ...
  console.log(url, async, success)
}
登入後複製

定義了一個預設參數async,url和success是必傳的,這時需要把中間的參數置為undefined

ajax('../user.action', undefined, function() {
   
})
登入後複製

注意,不要想當然的把undefined改為null,  即使 null == undefined, 傳null後,函數體內的async就是null不是true了。

以下幾點要注意:

1. 定義了預設參數後,函數的length屬性會減少,即有幾個預設參數不包含在length的計算當中

function calc(x=0, y=0) {
  // ...
  console.log(x, y)
}
function ajax(url, async=true, dataType="JSON") {
  // ...
  console.log(url, async, dataType)
}
console.log(calc.length); // 0
console.log(ajax.length); // 1

登入後複製

2. 不能用let和const再宣告預設值,var可以

function ajax(url="../user.action", async=true, success) {
  var url = ''; // 允许
  let async = 3; // 报错
  const success = function(){}; // 报错
}

登入後複製

另外比較有趣的是:預設參數可以不是一個值類型,它可以是一個函數呼叫

function getCallback() {
  return function() {
    // return code
  }
}
 
function ajax(url, async, success=getCallback()) {
  // ...
  console.log(url, async, success)
}
登入後複製

可以看到這裡參數success是一個函數調用,調用ajax時如果沒有傳第三個參數,則會執行getCallback函數,該函數返回一個新函數賦值給success。這是一個很強大的功能,給程式設計師一個很大的想像發揮空間。

例如,利用這個特性可以強制指定某參數必須傳,不傳就報錯

function throwIf() {
  throw new Error('少传了参数');
}
 
function ajax(url=throwIf(), async=true, success) {
  return url;
}
ajax(); // Error: 少传了参数
登入後複製

以上所述就是本文的全部內容了,希望大家能夠喜歡。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
java - springboot新手學習
來自於 1970-01-01 08:00:00
0
0
0
spring - JavaWeb中 Service 層的事務問題
來自於 1970-01-01 08:00:00
0
0
0
java - C語言演算法題-韓信點兵 解法?
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板