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

这篇文章主要是对Javascript动态方法调用与参数修改的问题进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助

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"


可见,外层函数对于内层函数的调用栈是可见的,可修改的。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wdwjgf.html