DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 深入淺析JS是按值傳遞還是按引用傳遞(推薦)
深入淺析JS是按值傳遞還是按引用傳遞(推薦)
編輯:關於JavaScript     

按值傳遞(call by value)是最常用的求值策略:函數的形參是被調用時所傳實參的副本。修改形參的值並不會影響實參。

  按引用傳遞(call by reference)時,函數的形參接收實參的隱式引用,而不再是副本。這意味著函數形參的值如果被修改,實參也會被修改。同時兩者指向相同的值。

  按引用傳遞會使函數調用的追蹤更加困難,有時也會引起一些微妙的BUG。

  按值傳遞由於每次都需要克隆副本,對一些復雜類型,性能較低。兩種傳值方式都有各自的問題。

  JS的基本類型,是按值傳遞的。

var a = 1;
function foo(x) {
x = 2;
}
foo(a);
console.log(a); // 仍為1, 未受x = 2賦值所影響

  再來看看對象的傳遞:

var obj = {x : 1};
function foo(o) {
o.x = 3;
}
foo(obj);
console.log(obj.x); // 3, 被修改了! 
var obj = {x : 1};
function foo(o) {
o = 100;
}
foo(obj);
console.log(obj.x); // 仍然是1, obj並未被修改為100.

  可以看出,對象的值得傳遞並不是按引用傳遞。其實,按共享傳遞 call by sharing,准確的說,JS中的基本類型按值傳遞,對象類型按共享傳遞的(call by sharing,也叫按對象傳遞、按對象共享傳遞)。

  該策略的重點是:調用函數傳參時,函數接受對象實參引用的副本(既不是按值傳遞的對象副本,也不是按引用傳遞的隱式引用)。 它和按引用傳遞的不同在於:在共享傳遞中對函數形參的賦值,不會影響實參的值。

  總之,基本類型是按值傳遞,而對於對象來說傳入的是對象指向的地址,也可以認為其是特殊的按值傳遞。如果在函數內對對象的屬性進行操作,實際就是對其指向對象的屬性進行操作。但是,如果對其整體進行操作(比如:o = 100或者o = []),其實際是新定於了對象,實參的引用地址為新的對象的引用地址,與原來的引用沒有任何關系,所以不會對原來的對象造成改變。

以上所述是小編給大家介紹的JS是按值傳遞還是按引用傳遞(推薦)的全部知識,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的,在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved