JavaScript中的with使用是一種處理對(duì)象屬性的方法。當(dāng)我們需要多次使用一個(gè)對(duì)象的屬性時(shí),我們可以使用with來(lái)避免重復(fù)書寫對(duì)象名,從而簡(jiǎn)化代碼。with語(yǔ)句的結(jié)構(gòu)為:
with(object){ //執(zhí)行代碼 }
該語(yǔ)句將對(duì)象作為參數(shù)傳入with中,然后執(zhí)行花括號(hào)內(nèi)的代碼。在代碼塊中,我們可以直接使用對(duì)象的屬性名,而無(wú)需重復(fù)書寫對(duì)象名。
例如,我們需要獲取一個(gè)數(shù)組中的第一項(xiàng)和最后一項(xiàng)的值。既可以使用傳統(tǒng)的方式:
var first = arr[0]; var last = arr[arr.length-1];
也可以使用with語(yǔ)句:
with(arr){ var first = arr[0]; var last = arr[length-1]; }
通過(guò)with語(yǔ)句,我們可以省略掉多次書寫arr,更加簡(jiǎn)潔明了。但是,with語(yǔ)句并不是完美的解決辦法。使用with語(yǔ)句會(huì)影響代碼的性能,因?yàn)閣ith會(huì)將對(duì)象的屬性復(fù)制到一個(gè)新的詞法環(huán)境中,這會(huì)導(dǎo)致訪問(wèn)對(duì)象的屬性變慢。
同時(shí),with語(yǔ)句還會(huì)引發(fā)命名沖突的問(wèn)題。如果我們?cè)诖a塊中定義的變量與對(duì)象的屬性名相同,那么with語(yǔ)句中的代碼會(huì)優(yōu)先使用代碼塊中定義的變量,而不是對(duì)象中的屬性。這會(huì)使得代碼的行為不穩(wěn)定,因?yàn)槲覀儫o(wú)法確保變量與屬性名完全相同。
例如,假設(shè)我們定義了一個(gè)數(shù)組:
var arr = [1,2,3];
然后,我們使用with語(yǔ)句來(lái)遍歷數(shù)組:
with(arr){ for(var i = 0; i<length;i++){ var item = arr[i]; console.log(item); } }
代碼執(zhí)行過(guò)程中,我們?cè)谘h(huán)體中定義了一個(gè)名為item的變量。由于變量名與數(shù)組屬性名相同,這會(huì)導(dǎo)致代碼執(zhí)行異常。因?yàn)閣ith語(yǔ)句中的代碼會(huì)優(yōu)先使用變量,而不是數(shù)組的屬性。使用with語(yǔ)句要特別小心這類情況。
因此,雖然with語(yǔ)句會(huì)讓代碼變得簡(jiǎn)潔明了,但是我們不推薦使用它。如果你需要多次訪問(wèn)一個(gè)對(duì)象的屬性,可以考慮將對(duì)象屬性放入一個(gè)縮寫變量中,從而避免重復(fù)書寫對(duì)象名。例如:
var obj = {a:1,b:2,c:3}; var props = obj; var a = props.a; var b = props.b; var c = props.c;
這樣,我們就可以通過(guò)props來(lái)訪問(wèn)obj中的屬性,避免了重復(fù)書寫對(duì)象名。相比with語(yǔ)句,這種寫法更加安全可靠。