成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

js面向?qū)ο笾帘螌傩?

Pluser / 2799人閱讀

摘要:什么是屏蔽屬性一條賦值語句引出的思考如果對象中包含名為的普通數(shù)據(jù)訪問屬性,這條賦值語句只會(huì)修改已有的屬性值。然而,如果存在于原型鏈上層,賦值語句的行為就會(huì)有些不同而且可能很出人意料。總之,不會(huì)發(fā)生屏蔽。

1.什么是屏蔽屬性

一條賦值語句引出的思考:

myObject.foo = "bar";

如果myObject 對象中包含名為foo 的普通數(shù)據(jù)訪問屬性,這條賦值語句只會(huì)修改已有的屬
性值。
如果foo 不是直接存在于myObject 中,[[Prototype]] 鏈就會(huì)被遍歷,類似[[Get]] 操作。
如果原型鏈上找不到foo,foo 就會(huì)被直接添加到myObject 上。
然而,如果foo 存在于原型鏈上層,賦值語句myObject.foo = "bar" 的行為就會(huì)有些不同
(而且可能很出人意料)。稍后我們會(huì)進(jìn)行介紹。
如果屬性名foo 既出現(xiàn)在myObject 中也出現(xiàn)在myObject 的[[Prototype]] 鏈上層, 那
么就會(huì)發(fā)生屏蔽。myObject 中包含的foo 屬性會(huì)屏蔽原型鏈上層的所有foo 屬性,因?yàn)?br>myObject.foo 總是會(huì)選擇原型鏈中最底層的foo 屬性。

2.屏蔽比我們想象中更加復(fù)雜

下面我們分析一下如果foo 不直接存在于myObject 中而是存在于原型鏈上層時(shí)myObject.foo = "bar" 會(huì)出現(xiàn)的三種情況。

如果在[[Prototype]] 鏈上層存在名為foo 的普通數(shù)據(jù)訪問屬性并且沒有被標(biāo)記為只讀(writable:false),那就會(huì)直接在myObject 中添加一個(gè)名為foo 的新屬性,它是屏蔽屬性。

如果在[[Prototype]] 鏈上層存在foo,但是它被標(biāo)記為只讀(writable:false),那么無法修改已有屬性或者在myObject 上創(chuàng)建屏蔽屬性。如果運(yùn)行在嚴(yán)格模式下,代碼會(huì)拋出一個(gè)錯(cuò)誤。否則,這條賦值語句會(huì)被忽略??傊?,不會(huì)發(fā)生屏蔽。

如果在[[Prototype]] 鏈上層存在foo 并且它是一個(gè)setter(參見第3 章),那就一定會(huì)調(diào)用這個(gè)setter。foo 不會(huì)被添加到(或者說屏蔽于)myObject,也不會(huì)重新定義foo 這個(gè)setter。

3.你所不知道的屏蔽屬性

大多數(shù)開發(fā)者都認(rèn)為如果向[[Prototype]] 鏈上層已經(jīng)存在的屬性([[Put]])賦值,就一定會(huì)觸發(fā)屏蔽,但是如你所見,三種情況中只有一種(第一種)是這樣的。
如果你希望在第二種和第三種情況下也屏蔽foo,那就不能使用= 操作符來賦值,而是使用Object.defineProperty(..)(參見第3 章)來向myObject 添加foo。

4.JavaScript中的屬性:定義和賦值的區(qū)別

1.賦值可能會(huì)調(diào)用原型上的setter(sub與sup里面有同名屬性),定義會(huì)創(chuàng)建一個(gè)自身屬性

2.原型鏈中的同名只讀屬性可能會(huì)阻止賦值操作(如上的非屏蔽操作),但不會(huì)阻止定義操作

3.賦值運(yùn)算符不會(huì)改變原型鏈上的屬性

4.只有通過定義操作,才能創(chuàng)建一個(gè)擁有指定特性的屬性(Object.defineProperty的威力)

5.對象字面量中的屬性是通過定義操作添加的

了解更詳細(xì)的信息可以參考:http://www.cnblogs.com/ziyunf...

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

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88102.html

相關(guān)文章

  • JS面向對象的程序設(shè)計(jì)繼承的實(shí)現(xiàn)-寄生組合式繼承

    摘要:組合繼承最大的問題就是無論在什么情況下,都會(huì)調(diào)用兩次超類型構(gòu)造函數(shù)一次是在創(chuàng)建子類型原型的時(shí)候。好在,我們已經(jīng)找到了解決這個(gè)問題方法寄生組合式繼承所謂寄生組合式繼承,即通過借用構(gòu)造函數(shù)來繼承屬性,通過原型鏈的混成形式來繼承方法。 寄生組合式繼承 組合繼承是JavaScript最常用的繼承模式。 不過,它也有自己的不足。 組合繼承最大的問題就是無論在什么情況下,都會(huì)調(diào)用兩次超類型構(gòu)造函數(shù)...

    y1chuan 評論0 收藏0
  • 寫給Java開發(fā)者看的JavaScript對象機(jī)制

    摘要:如果你已經(jīng)對機(jī)制已有了解,但是由于兩者對象機(jī)制的巨大本質(zhì)差異,對它和構(gòu)造函數(shù),實(shí)例對象的關(guān)系仍有疑惑,本文或許可以解答你的問題。所有的原型對象都會(huì)自動(dòng)獲得一個(gè)屬性,這個(gè)屬性的值是指向原型所在的構(gòu)造函數(shù)的指針。 幫助面向?qū)ο箝_發(fā)者理解關(guān)于JavaScript對象機(jī)制 本文是以一個(gè)熟悉OO語言的開發(fā)者視角,來解釋JavaScript中的對象。 對于不了解JavaScript 語言,尤其是習(xí)...

    Charles 評論0 收藏0
  • javascript面向對象繼承(上)

    摘要:使用原型鏈實(shí)現(xiàn)對原型屬性和方法的繼承,用借用構(gòu)造函數(shù)模式實(shí)現(xiàn)對實(shí)例屬性的繼承。 我們之前介紹了javascript面向?qū)ο蟮姆庋b的相關(guān)內(nèi)容,還介紹了js的call方法,今天開始討論js的繼承這篇文章參考了《javascript高級程序設(shè)計(jì)》(第三版),但內(nèi)容不局限于,網(wǎng)上很多關(guān)于js繼承的相關(guān)內(nèi)容都是來自于這本書,有興趣的同學(xué)可以翻閱查看 原型鏈繼承 我們先通過一個(gè)栗子,了解一下原型鏈...

    ivyzhang 評論0 收藏0
  • 前端進(jìn)擊的巨人(七):走進(jìn)面向對象,原型與原型鏈,繼承方式

    摘要:除了以上介紹的幾種對象創(chuàng)建方式,此外還有寄生構(gòu)造函數(shù)模式穩(wěn)妥構(gòu)造函數(shù)模式。 showImg(https://segmentfault.com/img/remote/1460000018196128); 面向?qū)ο?是以 對象 為中心的編程思想,它的思維方式是構(gòu)造。 面向?qū)ο?編程的三大特點(diǎn):封裝、繼承、多態(tài): 封裝:屬性方法的抽象 繼承:一個(gè)類繼承(復(fù)制)另一個(gè)類的屬性/方法 多態(tài):方...

    wums 評論0 收藏0
  • 面向對象的程序設(shè)計(jì)原型模式

    摘要:可以用刪除實(shí)例對象中自己添加的屬性可以確定屬性是原型中還是實(shí)例對象中,當(dāng)時(shí)實(shí)例對象中時(shí),返回的是操作符,有兩種使用方式,單獨(dú)使用和循環(huán)中。單獨(dú)使用,通過對象能夠訪問屬性時(shí)返回,無論時(shí)在原型中還是實(shí)例對象中。 原型模式,每個(gè)創(chuàng)建的對象都有一個(gè)prototype屬性,這個(gè)屬性是一個(gè)指針,指向一個(gè)對象,而這個(gè)對象的用途是包含可以由特定類型的所有實(shí)例共享的屬性和方法。 ------------...

    yunhao 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<