今天就跟大家聊聊有關JavaScript中in與hasOwnProperty有什么不同,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
in操作符只要通過對象能訪問到屬性就返回true。hasOwnProperty()
只在屬性存在于實例中時才返回true。
使用delete操作符則可以完全刪除實例屬性,從而讓我們能鞏固重新訪問原型中的屬性。
function Person(){ } Person.prototype.name = "Nicholas"; Person.prototype.age = 29; Person.prototype.job = "Software Engineer"; Person.prototype.sayName = function(){ alert(this.name); }; var person1 = new Person(); var person2 = new Person(); alert(person1.hasOwnProperty("name"));//false alert("name" in person1);//true person1.name = "Greg"; alert(person1.name);//"Greg" alert(person1.hasOwnProperty("name"));//true alert("name" in person1);//true delete person1.name; alert(person1.name);//"Nicholas" alert(person1.hasOwnProperty("name"));//false alert("name" in person1);//true
prototype
1.每個函數都有一個 prototype 的對象屬性,對象內有一個 constructor 屬性,默認指向函數本身
2.每個對象都有一個 __proto__ 的屬性,屬相指向其父類型的 prototype
構造函數和普通函數并沒有區別,使用 new 關鍵字調用就是構造函數,使用構造函數可以 實例化 一個對象
函數的返回值有兩種可能
1.顯式調用 return 返回 return 后表達式的求值
2.沒有調用 return 返回 undefined
function People(name, age) { this.name = name; this.age = age; } var people = new People('Byron', 26);
構造函數返回值
1.沒有返回值
2.簡單數據類型
3.對象類型
看完上述內容,你們對JavaScript中in與hasOwnProperty有什么不同有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。