在函数中,是可以使用函数名作为另一个函数的参数的,执行时相当于是对此函数的一次引用。
例如我们要创建不定参数数量的函数,最后一个参数是要执行的函数
var fn = function () {// 获取所有参数
var args = [].slice.call(arguments)
// 如果最后一个参数不是函数,则不继续执行下面的内容
var caller = args.pop()
if (typeof caller !== "function")
return
// 接下来是对所有参数进行操作
...
// 假设操作完了之后的变量数组仍为args,把这些变量置入要执行的函数中
caller.apply(this, args)
}
1.php有个很方便的用法是在定义函数时可以直接给参数设默认值,如:<br><br>function simue ($a=1,$b=2){<br> return $a+$b<br>}<br>echo simue()//输出3<br>echo simue(10)//输出12<br>echo simue(10,20)//输出30<br><br>但js却不能这么定义,如果写function simue(a=1,b=2){}会提示缺少对象。<br><br>2.js函数中有个储存参数的数组arguments ,所有函数获得的参数会被编译器挨个保存到这个数组中。于是我们的js版支持参数默认值的函数可以通过另外一种变通的方法实现,修改上例:<br><br>function simue (){<br> var a = arguments[0] ? arguments[0] :<br>1<br> var b = arguments[1] ? arguments[1] :<br>2<br> return a+b<br>}<br>alert( simue() )//输出3<br>alert( simue(10) )//输出12<br>alert( simue(10,20) )//输出30