javascript中hasOwnProperty() 方法使用指南
概述
hasOwnProperty() 方法用來判斷某個對象是否含有指定的自身屬性。
語法
obj.hasOwnProperty(prop)
參數(shù)
•prop
•要檢測的屬性名稱。
描述
所有繼承了 Object.prototype 的對象都會從原型鏈上繼承到 hasOwnProperty 方法,這個方法可以用來檢測一個對象是否含有特定的自身屬性,和 in 運算符不同,該方法會忽略掉那些從原型鏈上繼承到的屬性。
示例
例1:使用 hasOwnProperty 方法判斷某對象是否含有特定的自身屬性
下面的例子檢測了對象 o 是否含有自身屬性 prop:
o = new Object();o.prop = 'exists';function changeO() {
o.newprop = o.prop;
delete o.prop;}o.hasOwnProperty('prop');
// 返回 true
changeO();
o.hasOwnProperty('prop');
// 返回 false
例2:自身屬性和繼承屬性的區(qū)別
下面的例子演示了 hasOwnProperty 方法對待自身屬性和繼承屬性的區(qū)別:
o = new Object();o.prop = 'exists';o.hasOwnProperty('prop');
// 返回 true
o.hasOwnProperty('toString');
// 返回 false
o.hasOwnProperty('hasOwnProperty');
// 返回 false
例3:遍歷一個對象的所有自身屬性
下面的例子演示了如何在遍歷一個對象的所有屬性時忽略掉繼承屬性,注意這里 for..in 循環(huán)只會遍歷可枚舉屬性,這通常就是我們想要的,直接使用 Object.getOwnPropertyNames() 方法也可以實現(xiàn)類似的需求。
var buz = {
fog: 'stack'};
for (var name in buz) {
if (buz.hasOwnProperty(name)) {
alert("this is fog (" + name + ") for sure. Value: " + buz[name]);
}
else {
alert(name);
// toString or something else
}}
例4: hasOwnProperty 方法有可能被遮蔽
如果一個對象擁有自己的 hasOwnProperty 方法, 則原型鏈上的同名方法會被遮蔽(shadowed):
var foo = {
hasOwnProperty: function() {
return false;
},
bar: 'Here be dragons'};foo.hasOwnProperty('bar');
// 始終返回 false
// 如果擔心這種情況,可以直接使用原型鏈上真正的 hasOwnProperty 方法
({}).hasOwnProperty.call(foo, 'bar');
// true
Object.prototype.hasOwnProperty.call(foo, 'bar');
// true
以上就是本文所述的全部內容了,希望大家能夠喜歡。
相關文章
JavaScipt中的Math.ceil() 、Math.floor() 、Math.round() 三個函數(shù)的理解
以前一直會三個函數(shù)的使用產生混淆,現(xiàn)在通過對三個函數(shù)的原型定義的理解,其實很容易記住三個函數(shù)。2010-04-04setTimeout和setInterval的瀏覽器兼容性分析
setTimeout和setInterval的瀏覽器兼容性分析...2007-02-02JavaScript高級程序設計(第3版)學習筆記6 初識js對象
砌好墻,下面出場的就是房子了,在ECMAScript中,對象就是我們所說的房子,至于你所寫的整個應用程序,那就是一整套建筑群了2012-10-10JavaScript中的setUTCDate()方法使用詳解
這篇文章主要介紹了JavaScript中的setUTCDate()方法使用詳解,是JS入門學習中的基礎知識,需要的朋友可以參考下2015-06-06JavaScript charCodeAt方法入門實例(用于取得指定位置字符的Unicode編碼)
這篇文章主要介紹了JavaScript charCodeAt方法入門實例,charCodeAt方法用于取得指定位置字符的Unicode編碼,需要的朋友可以參考下2014-10-10