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

前端技术 2023/09/03 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.stayed.cn/item/7308

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。