如何提供 Function 的 Default Object Parameter ?

栏目: JavaScript · 发布时间: 7年前

内容简介:實務上 Function 的 Argument 應盡量以 Object 傳遞,而非 Primitive,但若要對 Property 提供 Default Value,該怎樣實現才優雅呢 ?ECMAScript 5ECMAScript 2015

實務上 Function 的 Argument 應盡量以 Object 傳遞,而非 Primitive,但若要對 Property 提供 Default Value,該怎樣實現才優雅呢 ?

Version

ECMAScript 5

ECMAScript 2015

ECMAScript 5

function func(options) {
  var firstName = '';
  var lastName = '';

  if (!options || !options.firstName)
    firstName = 'Sam';

  if (!options || !options.lastName) {
    lastName = 'Xiao';
  }

  return `${firstName} ${lastName}`;
}

console.log(func());
console.log(func({}));

options parameter 可能為 undefined ,也就是沒傳,或者傳入是 empty object。

因此要判斷 parameter 是否為 undefined ,還要判斷 property 是否為 undefined

由於 ES5 原本風格就是要你在 runtime 判斷並提供 default value,因此無法討避醜陋的寫法。

如何提供 Function 的 Default Object Parameter ?

ECMAScript 2015

function func({firstName = 'Sam', lastName = 'Xiao'} = {}) {
  return `${firstName} ${lastName}`;
}

console.log(func());
console.log(func({}));

ECMAScript 2015 提供了 Object Destructing 之後,我們可以不用宣告 parameter object,直接在 parameter list 加以 destruct variable,並提供 default value。

這種寫法在 ECMAScript 2015 經常看到,但老實說並不是最優雅的寫法。

Parameter 使用 object 的用意為的就是讓 parameter list 能越精簡越好,但使用了 Object Destructing 且提供 default value 之後,就喪失使用 object 的優勢了。

如何提供 Function 的 Default Object Parameter ?

function func(options = {}) {
  const {
    firstName = 'Sam',
    lastName = 'Xiao',
  } = options;

  return `${firstName} ${lastName}`;
}

console.log(func());
console.log(func({}));

比較優雅的寫法是 parameter list 僅提供 empty object,但 Object Destructing 則寫在 function 內,如此 parameter list 維持精簡,也保留了 parameter 使用 object 的初衷,且 destruct variable 寫在 function body 更一目瞭然。

如何提供 Function 的 Default Object Parameter ?

Conclusion

  • Object Destructing 是 ECMAScript 2015 很精彩的功能,但若要提供 default value,建議不要直接寫在 parameter list,而是分開寫

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C++程序设计原理与实践

C++程序设计原理与实践

(美)Bjarne Stroustrup / 王刚 等 / 机械工业出版社 / 2010.7 / 108.00元

本书是经典程序设计思想与C++开发实践的完美结合,是C++之父回归校园后对C++编程原理和技巧的全新阐述。书中全面地介绍了程序设计基本原理,包括基本概念、设计和编程技术、语言特性以及标准库等,教你学会如何编写具有输入、输出、计算以及简单图形显示等功能的程序。此外,本书通过对C++思想和历史的讨论、对经典实例(如矩阵运算、文本处理、测试以及嵌入式系统程序设计)的展示,以及对C语言的简单描述,为你呈现......一起来看看 《C++程序设计原理与实践》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具