JavaScript est amusant. Prenons cet exemple?:
function changeStuff(a, b, c) { a = a * 10; b.item = "changed"; c = {item: "changed"}; } var num = 10; var obj1 = {item: "unchanged"}; var obj2 = {item: "unchanged"}; changeStuff(num, obj1, obj2); console.log(num); console.log(obj1.item); console.log(obj2.item);
Cela produit le résultat?:
10 changed unchanged
obj1
根本不是引用,則更改 obj1.item
不會對函數(shù)外部的 obj1
a un impact. num
將是 100
,而 obj2.item
將讀取“changed”
。相反,num
保持 10
且 obj2.item
保持“不變
”.Au lieu de cela, ce qui se passe, c'est que l'élément transmis est transmis par valeur. Mais un élément passé par valeur est lui-même une référence. Techniquement, cela s'appelle un appel partagé.
En pratique, cela signifie que si vous modifiez le paramètre lui-même (comme le fait num
和 obj2
),則不會影響輸入到范圍。但是,如果您更改參數(shù)的內(nèi)部,它將向上傳播(與 obj1
).