Heim  >  Artikel  >  Web-Frontend  >  深入理解Javascript动态方法调用与参数修改的问题_javascript技巧

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

WBOY
WBOYOriginal
2016-05-16 17:10:091109Durchsuche

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"

可见,外层函数对于内层函数的调用栈是可见的,可修改的。
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn