设置JavaScript函数的默认参数值

☆樱花仙子☆ 提交于 2019-12-04 18:44:40

我希望JavaScript函数具有我设置了默认值的可选参数,如果未定义值,则使用该参数(如果传递值,则将其忽略)。 在Ruby中,您可以这样操作:

def read_file(file, delete_after = false)
  # code
end

这可以在JavaScript中使用吗?

function read_file(file, delete_after = false) {
  // Code
}

#1楼

在ECMAScript 6中,您实际上将能够准确地写出您拥有的东西:

function read_file(file, delete_after = false) {
  // Code
}

如果不存在或undefined它将delete_after设置为false 。 您现在可以将诸如Babel这样的编译器与ES6功能一起使用。

有关更多信息,请参见MDN文章


#2楼

作为更新...使用ECMAScript 6,您可以像下面这样在函数参数声明中最终设置默认值:

function f (x, y = 7, z = 42) {
  return x + y + z
}

f(1) === 50

如参考-http://es6-features.org/#DefaultParameterValues


#3楼

只需使用未定义的显式比较即可。

function read_file(file, delete_after)
{
    if(delete_after === undefined) { delete_after = false; }
}

#4楼

该解决方案适用于js:

function read_file(file, delete_after) {
    delete_after = delete_after || false;
    // Code
}

#5楼

作为一位长期的C ++开发人员(Rookie到Web开发的新手:)),当我第一次遇到这种情况时,我在函数定义中进行了参数分配,就像在问题中提到的那样,如下所示。

function myfunc(a,b=10)

但是请注意,它在所有浏览器中均无法正常工作。 对我来说,它适用于我的桌面上的chrome,但不适用于android上的chrome。 如上文所述,更安全的选择是-

    function myfunc(a,b)
    {
    if (typeof(b)==='undefined') b = 10;
......
    }

这个答案的目的不是要重复其他人已经提到过的相同解决方案,而是要告知函数定义中的参数分配可能在某些浏览器上有效,但不要依赖它。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!