我是靠谱客的博主 潇洒心情,这篇文章主要介绍深入理解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"

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

最后

以上就是潇洒心情最近收集整理的关于深入理解Javascript动态方法调用与参数修改的问题的全部内容,更多相关深入理解Javascript动态方法调用与参数修改内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(167)

评论列表共有 0 条评论

立即
投稿
返回
顶部