欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解讀new?Object()和Object.create()的區(qū)別

 更新時(shí)間:2023年02月10日 14:46:00   作者:xianghong_yang  
這篇文章主要介紹了解讀new?Object()和Object.create()的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Object.create()

創(chuàng)建一個(gè)新對(duì)象,使用現(xiàn)有的對(duì)象來(lái)提供新創(chuàng)建的對(duì)象的__proto__。 --MDN

語(yǔ)法

Object.create(proto, [propertiesObject]);

參數(shù)

proto:傳遞一個(gè)現(xiàn)在有的對(duì)象,即新對(duì)象的原型對(duì)象(新創(chuàng)建的對(duì)象_proto_屬性指向現(xiàn)有屬性)。

第一個(gè)參數(shù)proto的值為null,那么創(chuàng)建出來(lái)的對(duì)象是一個(gè){}(空對(duì)象)并且沒(méi)有原型;

Objecr.create({name:'lili'});

Objecr.create(null);

propertiesObject:可選,給新對(duì)象添加新屬性以及描述器。如果沒(méi)有指定即創(chuàng)建一個(gè){},有原型也有繼承Object.prototype上的方法。。

返回值

一個(gè)新對(duì)象,帶著指定的原型對(duì)象和屬性

小試牛刀

//題目
var a = {num:2};
var b = Object.create(a);
//問(wèn)題,以下順序執(zhí)行,值是?
b.num
b.num++ 
a.num 
1. b.num == 2
Object.create()方法創(chuàng)建一個(gè)新對(duì)象,使用現(xiàn)有的對(duì)象來(lái)提供新創(chuàng)建的對(duì)象的__proto__。
也就是b.__proto__ == a
所以雖然b是個(gè)空對(duì)象,但會(huì)從原型上一直找值。
b.num == b.__proto__.num == 2
2. b.num++ == 2
b.num為2,++運(yùn)算符是先用后加,這時(shí)b.num++還是2
3. a.num == 2
b.num 在執(zhí)行 ++ 操作之后,這時(shí)的b為{num:3},不影響a.

new Object()

new創(chuàng)建一個(gè)用戶定義的對(duì)象類型的實(shí)例或具有構(gòu)造函數(shù)的內(nèi)置對(duì)象的實(shí)例。

  • 創(chuàng)建一個(gè)空的對(duì)象(即{})
  • 鏈接該對(duì)象(即設(shè)置該對(duì)象的構(gòu)造函數(shù))到另一個(gè)對(duì)象
  • 將步驟1新創(chuàng)建的對(duì)象作為this的上下文
  • 如果該函數(shù)沒(méi)有返回對(duì)象,則返回this
  • new會(huì)創(chuàng)建一個(gè)新對(duì)象,并且這個(gè)新對(duì)象繼承構(gòu)造函數(shù)的prototype,也就是說(shuō)創(chuàng)建的實(shí)例的proto指向構(gòu)造函數(shù)的prototype
  • new Object()會(huì)創(chuàng)建一個(gè)實(shí)例,該實(shí)例的proto指向Object的prototype
new Object();

new Object({name:'lili'});

區(qū)別

new Object()繼承內(nèi)置對(duì)象Object,而Object.create()則是繼承指定對(duì)象可以通過(guò)Object.create(null) 創(chuàng)建一個(gè)干凈的對(duì)象,也就是沒(méi)有原型,而 new Object()創(chuàng)建的對(duì)象是 Object的實(shí)例,原型永遠(yuǎn)指向Object.prototype 

創(chuàng)建對(duì)象new Object() 和 Object.create()區(qū)分

new Object() 和 Object.create() 創(chuàng)建對(duì)象有什么不同之處,先看一個(gè)例子:

  var foo = {
    something: function() {
        console.log( "Tell me something good..." );
    }
};
foo.c = 1
var a = Object.create( foo );
var b = new Object(foo)
foo.foo='foo'
a.a='a'
b.b = 'b'
b.something()
a.something(); // Tell me something good...
console.log('a:',a)
console.log('b:',b)
console.log('foo:',foo)

打印結(jié)果:

b.something(); //Tell me something good…
a.something(); // Tell me something good…
console.log(‘a:’,a) // a: {a: “a”}
console.log(‘b:’,b) //b: {c: 1, foo: “foo”, b: “b”, something: ƒ}
console.log(‘foo:’,foo) //foo: {c: 1, foo: “foo”, b: “b”, something: ƒ}

發(fā)現(xiàn):

在控制臺(tái)上打印,看出這兩種創(chuàng)建對(duì)象區(qū)別,十分清晰,create創(chuàng)建的對(duì)象只是原型指向foo,之后它倆無(wú)任何關(guān)系了,無(wú)論foo怎么修改,都不會(huì)影響a,a添加屬性也不會(huì)影響foo,new 方式則會(huì)相互影響擴(kuò)展

當(dāng)要設(shè)計(jì)通用組件或模塊時(shí),假設(shè)要調(diào)用 a.something(),如果 a中不存在 something()時(shí)這條語(yǔ)句也可以正常工作的話,那你的 API 設(shè)計(jì)就會(huì)變得很“神奇”,對(duì)于未來(lái)維護(hù)者來(lái)說(shuō)這可能不太好理解。

但是你可以讓你的 API 設(shè)計(jì)不那么“神奇”,同時(shí)仍然能發(fā)揮 [[Prototype]] 關(guān)聯(lián)的威力:

var foo= {
	something: function() {
		console.log( "something!" );
	}
};
var a= Object.create(foo);
a.doSomething= function() {
	this.something(); // 內(nèi)部委托!
};
a.doSomething(); // "something!"

這里我們調(diào)用的 a.doSomething() 是實(shí)際存在于 a中的,這可以讓我們的 API 設(shè)計(jì)更加清晰(不那么“神奇”)。從內(nèi)部來(lái)說(shuō),我們的實(shí)現(xiàn)遵循的是委托設(shè)計(jì)模式,通過(guò) [[Prototype]] 委托到foo.something()。

小結(jié)一下吧:

Object.create(…) 會(huì)創(chuàng)建一個(gè)新對(duì)象(bar)并把它關(guān)聯(lián)到我們指定的對(duì)象(foo),這樣 我們就可以充分發(fā)揮 [[Prototype]] 機(jī)制的威力(委托)并且避免不必要的麻煩(比如使 用 new 的構(gòu)造函數(shù)調(diào)用會(huì)生成 .prototype 和 .constructor 引用)。。create()則不會(huì)生成這些引用,避免一些不必要的麻煩

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • javascript實(shí)現(xiàn)復(fù)選框選中屬性

    javascript實(shí)現(xiàn)復(fù)選框選中屬性

    本文給大家介紹的是一篇國(guó)外網(wǎng)友寫(xiě)的博客,講解的是關(guān)于實(shí)現(xiàn)復(fù)選框選中屬性的問(wèn)題,感覺(jué)非常不錯(cuò),翻譯過(guò)來(lái)推薦給大家,希望小伙伴們能夠喜歡。
    2015-03-03
  • JavaScript基于ChatGPT實(shí)現(xiàn)打字機(jī)消息回復(fù)

    JavaScript基于ChatGPT實(shí)現(xiàn)打字機(jī)消息回復(fù)

    ChatGPT 是一個(gè)基于深度學(xué)習(xí)的大型語(yǔ)言模型,處理自然語(yǔ)言需要大量的計(jì)算資源和時(shí)間,響應(yīng)速度肯定比普通的讀數(shù)據(jù)庫(kù)要慢的多,本文介紹了ChatGPT打字機(jī)消息回復(fù)實(shí)現(xiàn)原理,感興趣的同學(xué)可以跟著小編一起學(xué)習(xí)
    2023-05-05
  • 微信小程序?qū)崿F(xiàn)軌跡回放的示例代碼

    微信小程序?qū)崿F(xiàn)軌跡回放的示例代碼

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)軌跡回放的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • typescript配置alias的詳細(xì)步驟

    typescript配置alias的詳細(xì)步驟

    這篇文章主要介紹了typescript配置alias,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • js實(shí)現(xiàn)input密碼框提示信息的方法(附html5實(shí)現(xiàn)方法)

    js實(shí)現(xiàn)input密碼框提示信息的方法(附html5實(shí)現(xiàn)方法)

    這篇文章主要介紹了js實(shí)現(xiàn)input密碼框提示信息的方法,涉及JavaScript頁(yè)面元素的獲取,屬性判斷及樣式設(shè)置等技巧,并附帶html5的相關(guān)實(shí)現(xiàn)方法,需要的朋友可以參考下
    2016-01-01
  • 為你的微信小程序體積瘦身詳解

    為你的微信小程序體積瘦身詳解

    這篇文章主要給大家介紹了關(guān)于微信小程序瘦身的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-05-05
  • JavaScript動(dòng)畫(huà)原理之如何使用js進(jìn)行動(dòng)畫(huà)效果的實(shí)現(xiàn)

    JavaScript動(dòng)畫(huà)原理之如何使用js進(jìn)行動(dòng)畫(huà)效果的實(shí)現(xiàn)

    在現(xiàn)在做頁(yè)面很多時(shí)候都會(huì)用上動(dòng)畫(huà)效果,比如下拉菜單,側(cè)邊搜索欄,層的彈出與關(guān)閉等等,下面這篇文章主要給大家介紹了關(guān)于JavaScript動(dòng)畫(huà)原理之如何使用js進(jìn)行動(dòng)畫(huà)效果實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • js格式化貨幣數(shù)據(jù)實(shí)現(xiàn)代碼

    js格式化貨幣數(shù)據(jù)實(shí)現(xiàn)代碼

    貨幣數(shù)據(jù)想要一某種形式在頁(yè)面中顯示的話,首先是必須要格式化的,下面為大家介紹下具體的格式化代碼,感興趣的朋友可以參考下
    2013-09-09
  • JavaScript中String對(duì)象的使用方法以及實(shí)例

    JavaScript中String對(duì)象的使用方法以及實(shí)例

    這篇文章主要給大家介紹了關(guān)于JavaScript中String對(duì)象的使用方法以及實(shí)例的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),方便開(kāi)發(fā)者在JavaScript開(kāi)發(fā)中更好地處理字符串,需要的朋友可以參考下
    2022-04-04
  • 微信小程序日期時(shí)間選擇器使用方法

    微信小程序日期時(shí)間選擇器使用方法

    這篇文章主要為大家詳細(xì)介紹了微信小程序日期時(shí)間選擇器的使用方法,自定義精確到分秒或時(shí)段,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02

最新評(píng)論