国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:24:23
字體:
來源:轉載
供稿:網友

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的函數的按值傳遞參數(實例講解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 万荣县| 伊春市| 镇平县| 泽州县| 寻乌县| 新竹市| 通化市| 苍山县| 高雄县| 扎鲁特旗| 西乌珠穆沁旗| 新巴尔虎右旗| 弥渡县| 阿克苏市| 泗水县| 静乐县| 思茅市| 新乐市| 江门市| 密云县| 济源市| 通州区| 林口县| 绍兴市| 上犹县| 巢湖市| 朝阳区| 洞头县| 滦平县| 扬州市| 龙海市| 新乐市| 登封市| 新巴尔虎右旗| 孟连| 泗水县| 康平县| 容城县| 井陉县| 岳普湖县| 宜州市|