概述
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动态方法调用与参数修改的问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复