javascript中hasOwnProperty() 方法使用指南_基礎知識

來源:互聯網
上載者:User

概述

hasOwnProperty() 方法用來判斷某個對象是否含有指定的自身屬性。

文法
obj.hasOwnProperty(prop)

參數

•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:自身屬性和繼承屬性的區別

下面的例子示範了 hasOwnProperty 方法對待自身屬性和繼承屬性的區別:

複製代碼 代碼如下:

o = new Object();o.prop = 'exists';o.hasOwnProperty('prop');           
 // 返回 true
 o.hasOwnProperty('toString');        
 // 返回 false
 o.hasOwnProperty('hasOwnProperty');  
 // 返回 false

例3:遍曆一個對象的所有自身屬性

下面的例子示範了如何在遍曆一個對象的所有屬性時忽略掉繼承屬性,注意這裡 for..in 迴圈只會遍曆可枚舉屬性,這通常就是我們想要的,直接使用 Object.getOwnPropertyNames() 方法也可以實作類別似的需求。

複製代碼 代碼如下:

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

以上就是本文所述的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.