摘要:加一個成員方法執(zhí)行結(jié)果為注意到結(jié)果并沒有執(zhí)行,因為我們直接訪問了,而不是只有定義只讀屬性當一個屬性只有沒有的時候,我們是無法進行賦值操作的第一次初始化也不行,這一點也是相當?shù)乜印@缰挥袌?zhí)行結(jié)果為當沒有和時,就可以正常讀寫屬性
1. 背景
在es6中,我們可以用class關(guān)鍵字來定義類,語法如下
class Person { // 構(gòu)造函數(shù) constructor (name) { // 屬性初始化 this.name = name; } // 成員方法 sayName () { console.log(this.name); } // 靜態(tài)方法 static sayHi () { console.log("Hi~"); } }
其實本質(zhì)還是基于javascript原型鏈機制開發(fā)的語法糖,其中,本人對setter/getter進行一番研究,發(fā)現(xiàn)了不少坑。
2. 深入setter/getter 2.1 setter/getter的調(diào)用執(zhí)行時機class Person { constructor (name, age) { this.name = name; this.age = age; } set name (name) { console.log("setter"); this.name = name; } get name () { console.log("getter"); return this.name; } } var p = new Person("zhang", 25);
很快,我們就會發(fā)現(xiàn)代碼報錯了
到這里就可以明白了,原來只要this.name中的屬性名和set name/get name后面的name一致,對this.name就會調(diào)用setter/getter,也就是說setter/getter是hook函數(shù),而真實的存儲變量是_name,我們可以在代碼中直接獲取它。
class Person { constructor (name, age) { this.name = name; this.age = age; } set name (name) { console.log("setter"); this._name = name; } get name () { console.log("getter"); return this._name; } // 加一個成員方法 sayName () { console.log(this.name); } } var p = new Person("zhang", 25); console.log(p._name); // "zhang"
執(zhí)行結(jié)果為
注意到結(jié)果并沒有執(zhí)行g(shù)etter,因為我們直接訪問了p._name,而不是p.name
2.2 只有g(shù)etter定義只讀屬性當一個屬性只有g(shù)etter沒有setter的時候,我們是無法進行賦值操作的(第一次初始化也不行),這一點也是相當?shù)?b>坑。例如
class Person { constructor (name) { this.name = name; } // 只有g(shù)etter get name () { console.log("getter"); return this.name; } } var p = new Person("zhang");
執(zhí)行結(jié)果為
當沒有g(shù)etter和setter時,就可以正常讀寫屬性
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/88003.html
摘要:即必須有返回值其中可接受三個參數(shù),為目標對象,為屬性名,為實際接受的對象,默認為本例中新建的,如果單獨指出一個對象,可使指出對象受到相同的方法作用。且中的必須有返回值,的不用,這也正是因為在他之后還會執(zhí)行所以不需要。 ES6 Proxy/Reflect Proxy 攔截器 proxy是es6的新特性,簡單來講,即是對目標對象的屬性讀取、設(shè)置,亦或函數(shù)調(diào)用等操作進行攔截(處理)。 let...
摘要:關(guān)于有人說我用刪除這個屬性不就好了之后打印發(fā)現(xiàn)它還是一只哈士奇。如下的解釋如下操作符會從某個對象上移除指定屬性。 javascript-Object-Property ? javascript-對象的屬性的延伸學習 showImg(https://segmentfault.com/img/bVNH2S?w=640&h=640); 前言 在學習vue數(shù)據(jù)綁定的較底層原理時,被setter...
摘要:總結(jié)最后我們依照下圖參考深入淺出,再來回顧下整個過程在后,會調(diào)用函數(shù)進行初始化,也就是過程,在這個過程通過轉(zhuǎn)換成了的形式,來對數(shù)據(jù)追蹤變化,當被設(shè)置的對象被讀取的時候會執(zhí)行函數(shù),而在當被賦值的時候會執(zhí)行函數(shù)。 前言 Vue 最獨特的特性之一,是其非侵入性的響應(yīng)式系統(tǒng)。數(shù)據(jù)模型僅僅是普通的 JavaScript 對象。而當你修改它們時,視圖會進行更新。這使得狀態(tài)管理非常簡單直接,不過理解...
摘要:屬性描述符升級打怪必備技能對象有自己的屬性和方法,對于我們對象的屬性來講,屬性還有自己的屬性,又稱為屬性描述符。這個方法接受三個參數(shù),第一個是指定的對象,第二個是指定的對象參數(shù),第三個當然是要修改的屬性描述符了。 對象的聲明有倆種: 字面量 通過new一個構(gòu)造函數(shù)Object 兩者唯一的區(qū)別就是,字面量形式,可以一次賦值多個,通過new Object就得一個一個賦值 數(shù)據(jù)類型 ...
摘要:還提供了全部參數(shù)的構(gòu)造函數(shù)的自動生成,該注解的作用域也是只有在實體類上,因為只有實體類才會存在構(gòu)造函數(shù)。當然除了全部參數(shù)的構(gòu)造函數(shù),還提供了沒有參數(shù)的構(gòu)造函數(shù),使用方式與一致。 Lombok對于Java偷懶開發(fā)者來說應(yīng)該是比較中意的,恰恰筆者就是一個喜歡在小細節(jié)上偷懶來提高開發(fā)效率的人。所以在技術(shù)框架的海洋里尋找了很久才在GitHub開源平臺上找到,而在這之前國外很多程序猿一直使用該框...
閱讀 2566·2021-09-02 15:40
閱讀 1572·2019-08-30 15:54
閱讀 1086·2019-08-30 12:48
閱讀 3405·2019-08-29 17:23
閱讀 1052·2019-08-28 18:04
閱讀 3670·2019-08-26 13:54
閱讀 611·2019-08-26 11:40
閱讀 2400·2019-08-26 10:15