91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js的函數的按值傳遞參數(實例講解)

發布時間:2020-10-08 19:10:14 來源:腳本之家 閱讀:97 作者:參與商 欄目:web開發

js的函數傳參的方式是按值傳遞,正常情況下,改變函數參數的值,并不會對函數外部的變量造成影響。例如:

'use strict';
var list = [1, 2, 3];
list.forEach(function(item) {
 item ++;
});
console.log(list); // [ 1, 2, 3 ]

這是因為js的函數在接收參數時,會生成一個副本變量,該副本變量等于參數的值,可以分析js這樣運行的:

'use strict';
var list = [1, 2, 3];
list.forEach(function(item, i) {
 // 第一個item是副本,第二個item是數組元素list[i]
 var item = item;
 // 副本item++
 item ++;
 // 打印的是副本的值
 console.log(item); // 2, 3, 4
});
// 原數組不會改變
console.log(list); // [ 1, 2, 3 ]

但是當函數的參數傳遞的是一個對象呢?

'use strict';var list = [{a: 1, b: 2}];
list.forEach(function(item) {
 item.a ++;
});
console.log(list); // [ { a: 2, b: 2 } ]

發現函數內部居然改變了函數外部變量的值,那這又是為什么呢?

我們來分析js是如何運行這段代碼的

'use strict';
var list = [{a: 1, b: 2}];
list.forEach(function(item, i) {
 // 第一個item是副本,第二個item是數組元素list[i]
 var item = item;
 // 此時item和list[i]指向的是同一地址,故兩者完全一樣
 console.log(item === list[i]); // true
 // 此時item.a++ 亦即 list[i].a++
 item.a ++;
 // list[i]的值已經改變
 console.log(list[i]); // { a: 2, b: 2 }
});
console.log(list); // [ { a: 2, b: 2 } ]

那么為什么會產生這種情況呢?

由于js中對象屬于引用類型,var item = item 這一步相當于把 list[i] 的地址賦值給了item,他們兩個指向的都是原對象的地址,所以通過其中的一個去修改值時其實是修改他們指向的那個對象。例子中通過 item.a++ 方法改變了原對象的值,因此最后應該輸出 [ { a: 2, b: 2 } ]。

以上這篇js的函數的按值傳遞參數(實例講解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巫溪县| 周宁县| 台南县| 会同县| 肃南| 吴桥县| 盐津县| 确山县| 武安市| 黄龙县| 丹阳市| 江永县| 榆林市| 武邑县| 大石桥市| 静宁县| 财经| 和顺县| 五寨县| 青田县| 赤峰市| 包头市| 皋兰县| 兴隆县| 图木舒克市| 长子县| 庄河市| 东丽区| 中超| 綦江县| 丹阳市| 阜平县| 佛山市| 文成县| 乐昌市| 饶阳县| 望江县| 陕西省| 龙口市| 镇原县| 台东市|