国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

細(xì)說 Javascript 對象篇(三) : hasOwnProperty

elva / 1293人閱讀

摘要:方法是中唯一一個(gè)處理對象屬性而不會往上遍歷原型鏈的。在這里,只有能給出正確答案,這在遍歷一個(gè)對象的屬性時(shí)是非常必要的。這里還要提醒下,當(dāng)我們使用來遍歷對象時(shí),使用將會很好地避免來自原型對象擴(kuò)展所帶來的困擾。

判斷一個(gè)屬性是定義在對象本身而不是繼承自原型鏈,我們需要使用從 Object.prototype 繼承而來的 hasOwnProperty 方法。
hasOwnProperty 方法是 Javascript 中唯一一個(gè)處理對象屬性而不會往上遍歷原型鏈的。

// Poisoning 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 能給出正確答案,這在遍歷一個(gè)對象的屬性時(shí)是非常必要的。Javascript 中沒有其他方法能判斷一個(gè)屬性是定義在對象本身還是繼承自原型鏈。

hasOwnProperty 作為屬性

Javascript 并未將 hasOwnProperty 設(shè)為敏感詞,這意味著你可以擁有一個(gè)命名為 hasOwnProperty 的屬性。這個(gè)時(shí)候你無法再使用本身的 hasOwnProperty 方法來判斷屬性,所以你需要使用外部的 hasOwnProperty 方法來進(jìn)行判斷。

var foo = {
    hasOwnProperty: function() {
        return false;
    },
    bar: "Here be dragons"
};

foo.hasOwnProperty("bar"); // always returns false

// Use another Object"s hasOwnProperty and call it with "this" set to foo
({}).hasOwnProperty.call(foo, "bar"); // true

// It"s also possible to use hasOwnProperty from the Object
// prototype for this purpose
Object.prototype.hasOwnProperty.call(foo, "bar"); // true
總結(jié)

當(dāng)判斷對象屬性存在時(shí),hasOwnProperty 是唯一可以依賴的方法。這里還要提醒下,當(dāng)我們使用 for in loop 來遍歷對象時(shí),使用 hasOwnProperty 將會很好地避免來自原型對象擴(kuò)展所帶來的困擾。

參考

http://bonsaiden.github.io/JavaScript-Garden/#object.hasownproperty

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/78051.html

相關(guān)文章

  • 細(xì)說 Javascript 對象(四) : for in 循環(huán)

    摘要:第二是,由于會遍歷整個(gè)原型鏈,所以當(dāng)原型鏈過長時(shí),會對性能造成影響。總結(jié)建議養(yǎng)成過濾屬性的好習(xí)慣,不要對運(yùn)行環(huán)境做任何假設(shè),也無論原生的原型對象是否被擴(kuò)展。 如同 in 運(yùn)算符一樣,使用 for in 循環(huán)遍歷對象屬性時(shí),也將往上遍歷整個(gè)原型鏈。 // Poisoning Object.prototype Object.prototype.bar = 1; var foo = {m...

    Kross 評論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.32 - 七夕將至,你的“對象”還好嗎?

    摘要:很多情況下,通常一個(gè)人類,即創(chuàng)建了一個(gè)具體的對象。對象就是數(shù)據(jù),對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍(lán)圖或原型。在中,對象通過對類的實(shí)體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實(shí)例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...

    李昌杰 評論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.32 - 七夕將至,你的“對象”還好嗎?

    摘要:很多情況下,通常一個(gè)人類,即創(chuàng)建了一個(gè)具體的對象。對象就是數(shù)據(jù),對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍(lán)圖或原型。在中,對象通過對類的實(shí)體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實(shí)例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...

    Lyux 評論0 收藏0
  • SegmentFault 技術(shù)周刊 Vol.32 - 七夕將至,你的“對象”還好嗎?

    摘要:很多情況下,通常一個(gè)人類,即創(chuàng)建了一個(gè)具體的對象。對象就是數(shù)據(jù),對象本身不包含方法。類是相似對象的描述,稱為類的定義,是該類對象的藍(lán)圖或原型。在中,對象通過對類的實(shí)體化形成的對象。一類的對象抽取出來。注意中,對象一定是通過類的實(shí)例化來的。 showImg(https://segmentfault.com/img/bVTJ3H?w=900&h=385); 馬上就要到七夕了,離年底老媽老爸...

    AaronYuan 評論0 收藏0
  • 細(xì)說 Javascript 對象(一) : 對象的使用和屬性

    摘要:中的一切都可以視為對象,除了兩個(gè)特例和。上例中的第三個(gè)情形已說明刪除對象的屬性刪除屬性的唯一方法是使用,將屬性值設(shè)置為或只是移除了與屬性相關(guān)的值,并沒有真正刪除屬性本身。命名對象的屬性對象的屬性可以用普通字符或字符串來命名。 Javascript 中的一切都可以視為對象,除了兩個(gè)特例:null 和 undefined。 false.toString(); // false [1, 2...

    codecook 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<