javascript中hasOwnProperty() 方法使用指南

字號(hào):


    這篇文章主要詳細(xì)介紹了javascript中hasOwnProperty() 方法使用指南,非常的全面,推薦給有需要的小伙伴參考下。
    概述
    hasOwnProperty() 方法用來(lái)判斷某個(gè)對(duì)象是否含有指定的自身屬性。
    語(yǔ)法
    obj.hasOwnProperty(prop)
    參數(shù)
    •prop
    •要檢測(cè)的屬性名稱(chēng)。
    描述
    所有繼承了 Object.prototype 的對(duì)象都會(huì)從原型鏈上繼承到 hasOwnProperty 方法,這個(gè)方法可以用來(lái)檢測(cè)一個(gè)對(duì)象是否含有特定的自身屬性,和 in 運(yùn)算符不同,該方法會(huì)忽略掉那些從原型鏈上繼承到的屬性。
    示例
    例1:使用 hasOwnProperty 方法判斷某對(duì)象是否含有特定的自身屬性
    下面的例子檢測(cè)了對(duì)象 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 方法對(duì)待自身屬性和繼承屬性的區(qū)別:
    代碼如下:
    o = new Object();o.prop = 'exists';o.hasOwnProperty('prop');
    // 返回 true
    o.hasOwnProperty('toString');
    // 返回 false
    o.hasOwnProperty('hasOwnProperty');
    // 返回 false
    例3:遍歷一個(gè)對(duì)象的所有自身屬性
    下面的例子演示了如何在遍歷一個(gè)對(duì)象的所有屬性時(shí)忽略掉繼承屬性,注意這里 for..in 循環(huán)只會(huì)遍歷可枚舉屬性,這通常就是我們想要的,直接使用 Object.getOwnPropertyNames() 方法也可以實(shí)現(xiàn)類(lèi)似的需求。
    代碼如下:
    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 方法有可能被遮蔽
    如果一個(gè)對(duì)象擁有自己的 hasOwnProperty 方法, 則原型鏈上的同名方法會(huì)被遮蔽(shadowed):
    代碼如下:
    var foo = {
    hasOwnProperty: function() {
    return false;
    },
    bar: 'Here be dragons'};foo.hasOwnProperty('bar');
    // 始終返回 false
    // 如果擔(dān)心這種情況,可以直接使用原型鏈上真正的 hasOwnProperty 方法
    ({}).hasOwnProperty.call(foo, 'bar');
    // true
    Object.prototype.hasOwnProperty.call(foo, 'bar');
    // true
    以上就是本文所述的全部?jī)?nèi)容了,希望大家能夠喜歡。