可能的重复: 我如何使一个参数的默认值到一个javascript函数
在PHP中:
function func($a = 10, $b = 20){
// if func() is called with no arguments $a will be 10 and $ b will be 20
}
如何在JavaScript中做到这一点?
如果我试图在函数参数中赋值,就会得到一个错误
在形式参数之后
可能的重复: 我如何使一个参数的默认值到一个javascript函数
在PHP中:
function func($a = 10, $b = 20){
// if func() is called with no arguments $a will be 10 and $ b will be 20
}
如何在JavaScript中做到这一点?
如果我试图在函数参数中赋值,就会得到一个错误
在形式参数之后
不能为函数参数添加默认值。但是你可以这样做:
function tester(paramA, paramB){
if (typeof paramA == "undefined"){
paramA = defaultValue;
}
if (typeof paramB == "undefined"){
paramB = defaultValue;
}
}
你必须检查参数是否未定义:
function func(a, b) {
if (a === undefined) a = "default value";
if (b === undefined) b = "default value";
}
还要注意,这个问题以前已经回答过了。
ES2015 起:
从ES6/ES2015开始,我们在语言规范中有默认参数。所以我们可以做一些简单的事情,
function A(a, b = 4, c = 5) {
}
或结合ES2015解构,
function B({c} = {c: 2}, [d, e] = [3, 4]) {
}
如需详细解释,
https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Functions/default_parameters
默认函数参数允许使用默认值初始化形式参数,如果没有传递值或未定义。
前ES2015:
如果你要处理的值不是数字,字符串,布尔,NaN,或null,你可以简单地使用
(因此,对于不打算发送空值的对象、数组和函数,可以使用)
param || DEFAULT_VALUE
例如,
function X(a) {
a = a || function() {};
}
虽然这看起来很简单,而且有点工作,但这是有限制的,可能是反模式,因为||操作所有假值("",null, NaN, false, 0) -这使得该方法不可能将假值作为参数传递给参数。
因此,为了只显式地处理未定义的值,首选的方法是,
function C(a, b) {
a = typeof a === 'undefined' ? DEFAULT_VALUE_A : a;
b = typeof b === 'undefined' ? DEFAULT_VALUE_B : b;
}
function func(a, b)
{
if (typeof a == 'undefined')
a = 10;
if (typeof b == 'undefined')
b = 20;
// do what you want ... for example
alert(a + ',' + b);
}
在速记
function func(a, b)
{
a = (typeof a == 'undefined')?10:a;
b = (typeof b == 'undefined')?20:b;
// do what you want ... for example
alert(a + ',' + b);
}
在javascript中,你可以不带参数调用函数(即使它有参数)。
所以你可以像这样添加默认值:
function func(a, b){
if (typeof(a)==='undefined') a = 10;
if (typeof(b)==='undefined') b = 20;
//your code
}
然后你可以调用func();使用默认参数。
下面是一个测试:
function func(a, b){
if (typeof(a)==='undefined') a = 10;
if (typeof(b)==='undefined') b = 20;
alert("A: "+a+"\nB: "+b);
}
//testing
func();
func(80);
func(100,200);
我从未在JavaScript中见过这样做。如果你想要一个带有可选形参的函数,如果省略形参就会得到默认值,这里有一种方法:
function(a, b) {
if (typeof a == "undefined") {
a = 10;
}
if (typeof b == "undefined") {
a = 20;
}
alert("a: " + a + " b: " + b);
}