JavaScript中關(guān)于Object.create()的用法
JavaScript的Object.create()方法
ES5定義了一個(gè)名為Object.create()的方法,它創(chuàng)建一個(gè)對(duì)象,其中第一個(gè)參數(shù)就是這個(gè)對(duì)象的原型,Object.create()提供第二個(gè)可選參數(shù),用以對(duì)對(duì)象的屬性進(jìn)行進(jìn)一步描述。
// Object.create()是一個(gè)靜態(tài)方法
// 以下展示不同參數(shù)的用法
// 一個(gè)參數(shù)
var o = Object.create(null) // 相當(dāng)于空對(duì)象,任何屬性都沒有
var o = Object.create(Object.prototype) // 相當(dāng)于var o = {}
var o = Object.create({x: 1, y: 2}) // 相當(dāng)于var o = {}; o.prototype = {x: 1, y: 2}
// 第二個(gè)參數(shù)是一個(gè)對(duì)象,用于給創(chuàng)建的對(duì)象添加屬性和屬性描述的
// 屬性又分為數(shù)據(jù)屬性和存取器屬性
// 數(shù)據(jù)屬性的描述符對(duì)象的屬性有value(值)、writable(可寫性)、enumerable(可枚舉性)、configurable(可配置性)
// 存取器屬性的描述符對(duì)象的屬性有g(shù)et(讀取)、set(寫入)、enumerable(可枚舉性)、configurable(可配置性)
// 兩個(gè)參數(shù)
var o = Object.create({x: 1, y: 2}, {
a: {
value: 100,
......
}
}) // 向創(chuàng)建的對(duì)象o添加一個(gè)數(shù)據(jù)屬性a,值為100,其它描述屬性默認(rèn)為false
var o = Object.create({x: 1, y: 2}, {
a: {
get() {
return this.x + this.y
},
......
}
}) // 向創(chuàng)建的對(duì)象o添加一個(gè)存取器屬性a,o.a時(shí)執(zhí)行其get方法,set屬性默認(rèn)為undefined,其余描述屬性默認(rèn)為false
JavaScript手寫Object.create函數(shù)
給大家分享一下手寫 Object.create 函數(shù)。
函數(shù)功能
Object.create()方法創(chuàng)建一個(gè)新對(duì)象,使用現(xiàn)有的對(duì)象來提供新創(chuàng)建的對(duì)象的__proto__
代碼:
function create(parentPrototype, props) {
? function Fn() {
?
? }
? Fn.prototype = parentPrototype;
? let fn = new Fn();
? for (let key in props) {
? ? Object.defineProperty(fn, key, {
? ? ? enumerable: true, // 如果不枚舉對(duì)象中無法查看到這個(gè)對(duì)象
? ? ? ...props[key]
? ? })
? }
? return fn
}
?
?
function Parent() {
? this.name = "parent";
}
?
Parent.prototype.eat = function () {
? console.log("eat");
};
?
function Child() {
? this.age = 9;
? Parent.call(this);
}
?
Child.prototype = create(Parent.prototype, { constructor: { value: Child } });
?
// { constructor: { value: Child } } ?這段代碼保證 Child 的 prototype 的 constructor 還指向 Child 的構(gòu)造函數(shù)
?
let child = new Child();
console.log(child.constructor,'constructor'); // [Function: Child] 'constructor'
child.eat() // eat總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
前端使用pdf.js實(shí)現(xiàn)pdf轉(zhuǎn)為圖片
這篇文章主要為大家詳細(xì)介紹了前端如何使用pdf.js實(shí)現(xiàn)pdf轉(zhuǎn)為圖片功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
uniapp實(shí)現(xiàn)tabs切換(可滑動(dòng))效果實(shí)例
這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)tabs切換(可滑動(dòng))效果的相關(guān)資料,tabs切換無論是在app端還是小程序或者H5頁面都是很常見的功能,文中通過實(shí)例代碼介紹的很詳細(xì),需要的朋友可以參考下2023-07-07
JS實(shí)現(xiàn)隨機(jī)生成驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)隨機(jī)生成驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
處理JavaScript值為undefined的7個(gè)小技巧
這篇文章主要介紹了處理JavaScript值為undefined的7個(gè)小技巧,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
VsCode插件自動(dòng)生成注釋插件koroFileHeader使用教程
這篇文章主要介紹了VsCode插件自動(dòng)生成注釋插件koroFileHeader使用教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
JS將時(shí)間秒轉(zhuǎn)換成天小時(shí)分鐘秒的字符串
最近小編接到這樣的項(xiàng)目需求,接口返回的數(shù)據(jù)中時(shí)間單位為秒,但前端顯示的時(shí)候需要更人性化的帶有單位(天,小時(shí),分鐘,秒)的字符串;下面小編給大家?guī)韺?shí)例代碼,感興趣的朋友跟隨小編一起看看吧2019-07-07

