Javascript中可以對所傳參數在函數內進行修改,如下
function func1(name) {
name = 'lily';
alert(name);
}
func1('jack');//輸出🎜>
再看一個例子
程式碼如下:
this.name = n;
}
function fun2(name) {
fun1.call(this,'lily');
fun1.call(this,'lily');
fun1.call(this,'lily');
fun1(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"
可見,外層函數對於內層函數的呼叫棧是可見的,可修改的。