Maison  >  Article  >  interface Web  >  深入理解Javascript动态方法调用与参数修改的问题_javascript技巧

深入理解Javascript动态方法调用与参数修改的问题_javascript技巧

WBOY
WBOYoriginal
2016-05-16 17:10:091109parcourir

Javascript中可以对所传参数在函数内进行修改,如下

复制代码 代码如下:

function func1(name) {
    name = 'lily';
    alert(name);
}
func1('jack');//输出lily

再看一个例子
复制代码 代码如下:

function fun1(n) {
    this.name = n;
}
function fun2(name) {
    fun1.call(this,'lily');
    alert(name);
}
fun2("jack");//输出"jack"

fun1函数想把fun2调用时的参数修改为“lily”,但没有成功。弹出的仍然是“jack”。思考下为什么?

实际上fun1还是有能力把fun2调用时的参数给修改掉的,利用caller属性

复制代码 代码如下:

function fun1() {
    arguments.callee.caller.arguments[0] = 'lily';
}
function fun2(name) {
    fun1.call(this,name);
    alert(name);
}
fun2("jack");//输出"lily"

可见,外层函数对于内层函数的调用栈是可见的,可修改的。
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn