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

首頁 > 編程 > JavaScript > 正文

Javascript中的for in循環(huán)和hasOwnProperty結(jié)合使用

2019-11-20 22:39:53
字體:
供稿:網(wǎng)友
與in操作符相比,for in 在循環(huán)對象的屬性時也會遍歷原型鏈,for in 不會讀取不可枚舉屬性,如數(shù)組的length屬性。 小結(jié) 當檢測某個對象是否擁有某個屬性時,hasOwnProperty 是唯一可以完成這一任務(wù)的方法,在 for in 循環(huán)時,建議增加 hasOwnProperty 進行判斷,可以有效避免擴展本地原型而引起的錯誤。

與in操作符相比,for in 在循環(huán)對象的屬性時也會遍歷原型鏈,for in 不會讀取不可枚舉屬性,如數(shù)組的length屬性。

復制代碼 代碼如下:

// 擴展 Object.prototype
Object.prototype.bar = 1;
var foo = {moo: 2};
for(var i in foo) {
console.log(i); // 輸出 bar 和 moo
}


我們不可能改變 for in 循環(huán)的行為,當需要對循環(huán)體內(nèi)某些屬性進行過濾時,可以利用Object.prototype的hasOwnProperty方法來完成。

提示:因為 for in 循環(huán)總是遍歷整個原型鏈,所以當遍歷多繼承的對象時效率較低。

使用 hasOwnProperty 進行過濾

復制代碼 代碼如下:

// 仍舊針對上例的foo對象
for (var i in foo) {
if (foo.hasOwnProperty(i)) {
console.log(i);
}
}


例子中因為使用了hasOwnProperty,最終輸出moo;如果忽略 hasOwnProperty ,代碼將會輸出非預期結(jié)果,因為本地原型(如Object.prototype)已經(jīng)被擴展了。

Prototype框架就是擴展Javascript原始對象的一個類庫,并被廣泛使用,其缺點也很明顯,當框架引入后,如果不使用 hasOwnProperty 進行過濾判斷,輸出結(jié)果保證不是你想要的。

最佳實踐

推薦在 for in 時,總是使用 hasOwnProperty 進行判斷,沒人可以保證運行的代碼環(huán)境是否被污染過。

hasOwnProperty
為了檢查某個對象是否擁有不在原型鏈上的自定義屬性,就有必要用到 hasOwnProperty 方法,任何一個對象都具有該方法,它繼承自 Object.prototype。

提示:我們無法完全檢測某個屬性是否是undefined,因為屬性有可能存在,但其值為undefined。hasOwnProperty 是Javascript中唯一一個可以處理對象屬性而不遍歷原型鏈的方法。

復制代碼 代碼如下:

// 擴展 Object.prototype
Object.prototype.bar = 1;
var foo = {goo: undefined};

foo.bar; // 1
'bar' in foo; // true

foo.hasOwnProperty('bar'); // false
foo.hasOwnProperty('goo'); // true


只有 hasOwnProperty 給出了正確的預期結(jié)果,當遍歷對象的屬性時這是很有必要的,沒有其它辦法來排除定義在對象原型鏈上的屬性。

hasOwnProperty 作為屬性

Javascript 并沒有保護 hasOwnProperty 為關(guān)鍵字或保留字,因此,如果某個對象擁有同名的屬性,就有必要利用擴展的 hasOwnProperty 來獲取正確結(jié)果。

復制代碼 代碼如下:

var foo = {
hasOwnProperty: function() {
return false;
},
bar: 'Here be dragons'
};
foo.hasOwnProperty('bar'); // 總是返回 false
// 使用另一個 hasOwnProperty 并將 this 設(shè)置為 foo 來調(diào)用它
{}.hasOwnProperty.call(foo, 'bar'); // true


小結(jié)
當檢測某個對象是否擁有某個屬性時,hasOwnProperty 是唯一可以完成這一任務(wù)的方法,在 for in 循環(huán)時,建議增加 hasOwnProperty 進行判斷,可以有效避免擴展本地原型而引起的錯誤。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 阳信县| 蒲江县| 台北市| 白水县| 格尔木市| 桦川县| 西充县| 永靖县| 井冈山市| 图们市| 武陟县| 凉山| 云安县| 施甸县| 子洲县| 迁西县| 沿河| 毕节市| 弥渡县| 浠水县| 宁都县| 南涧| 兴山县| 靖宇县| 米脂县| 溧阳市| 永靖县| 永清县| 岳池县| 本溪| 尼勒克县| 昭苏县| 东光县| 麦盖提县| 隆回县| 厦门市| 合江县| 额济纳旗| 陇西县| 山阳县| 保定市|