es6 class實(shí)現(xiàn)靜態(tài)屬性、私有屬性丽柿、方法

1.class實(shí)現(xiàn)靜態(tài)屬性

參考:ES6 class 靜態(tài)屬性和私有方法

es6中實(shí)現(xiàn)了靜態(tài)方法恢准,但是沒(méi)有靜態(tài)屬性

class MyClass {
  constructor() {}
  static say() {}
}

以上的靜態(tài)方法相當(dāng)于

class MyClass {}
MyClass.say = function() {}

靜態(tài)屬性特點(diǎn):
1.儲(chǔ)存在類中的公共屬性,實(shí)例之間共享一份
2.不用實(shí)例化對(duì)象甫题,直接在類上可訪問(wèn)馁筐。例如MyClass.getName()

因?yàn)樵赾lass中只有this上的屬性,以及class外的變量可被訪問(wèn)坠非。

var age= 0
class MyClass {
  constructor(name) {
    this.name = name
  }
  getName() {
    return this.name 
  }
  getAge(value) {
    return age
  }
}

所以靜態(tài)屬性就是
class外的一個(gè)變量敏沉,并且通過(guò)靜態(tài)方法進(jìn)行訪問(wèn)

let name=""
class MyClass {
  static getName() {}
  static setName() {}
}

2.私有屬性

2.1 WeakMap實(shí)現(xiàn)私有屬性(可被繼承,不可直接被訪問(wèn))

WeakMap知識(shí)點(diǎn)參考:ES6 系列之 WeakMap炎码、ES6 class 靜態(tài)屬性和私有方法

私有屬性的特點(diǎn):不會(huì)暴露在外盟迟,不能通過(guò)this直接訪問(wèn)。子類不能繼承私有屬性

但是用WeakMap實(shí)現(xiàn)的私有屬性可被繼承潦闲。示例如下:
WeakMap以對(duì)象為鍵攒菠,Person實(shí)例化之后this指向?qū)嵗4藭r(shí)以this為鍵可實(shí)現(xiàn)一個(gè)實(shí)例儲(chǔ)存一份變量歉闰。
私有變量name不能通過(guò).name直接獲取到辖众,可以通過(guò)getName()獲取

const privateData = new WeakMap();

class Person {
    constructor() {
        this.name="name"
        privateData.set(this, { age: "age" });
    }

    getName() {
        return privateData.get(this).name;
    }
    getAge() {
        return privateData.get(this).age;
    }
}

 class Student extends Person{
    constructor(){
        super()
    }
 }
 let student=new Student()
 console.log(student)
console.log(student.getAge())
image.png

Student的constructor中調(diào)用了super所以Student的實(shí)例中的this也會(huì)作為key添加到privateData中卓起,value為{age:"age"}。所以WeakMap實(shí)現(xiàn)的私有屬性并沒(méi)有實(shí)現(xiàn)不可繼承的特點(diǎn)赵辕。

2.2 Symbol實(shí)現(xiàn)私有屬性

symbol知識(shí)點(diǎn):es6-symbol

由于Symbol可作為屬性名并且不能被for..in..、Object.key()概龄、Object.getOwnPropertyNames遍歷还惠。所以Symbol可以實(shí)現(xiàn)形式為_(kāi)name的私有屬性

const _counter = Symbol('counter');
const _action = Symbol('action');
class Countdown {
  constructor(counter, action) {
    this[_counter] = counter;
    this[_action] = action;
  }
}

與WeakMap實(shí)現(xiàn)的私有屬性相同,由于都在constructor中私杜,所以僅實(shí)現(xiàn)了私有屬性的不暴露蚕键,但是沒(méi)有實(shí)現(xiàn)不可繼承。

3. 私有方法

私有方法與私有屬性的區(qū)別僅在于一個(gè)是方法一個(gè)是屬性衰粹,所以同樣可以用WeakMap與Symbol來(lái)實(shí)現(xiàn)

3.1 WeakMap實(shí)現(xiàn)

由于要使調(diào)用privateFn時(shí)锣光,this指向Person實(shí)例,所以要用箭頭函數(shù)

const privateFns = new WeakMap()
class Person {
    constructor() {
        this.name="name"
        privateFns.set(this,{
            privateFn1:()=>{
            return this.name
            }
        })
    }
    userPrivateFn1(){
        console.log(privateFns.get(this).privateFn1())
    }
}
new Person().userPrivateFn1()//console.log.("name")

3.2 Symbol實(shí)現(xiàn)

const _privateFn1= Symbol()
class Person {
    constructor() {
        this.name="name"
        this[_privateFn1]=function () {
            return this.name
        }
    }
    userPrivateFn1(){
        console.log(this[_privateFn1]())
    }
}
new Person().userPrivateFn1()//console.log("name")

3.3 模塊中沒(méi)有export的方法

在一個(gè)類一個(gè).js文件的情況下铝耻,僅僅export default這個(gè)類誊爹,再在類外定義一些方法,這些沒(méi)有被export的方法就是私有方法瓢捉。用call()频丘、aply()、bind()的方法可以將這些私有方法的this指向類泡态。

<script type="module">
    import Person from "./test.js"
    new Person().userPrivateFn()//console.log("name")
</script>
function privateFn() {
    console.log(this.name)
}
export default class Person {
    constructor() {
        this.name="name"
    }
    userPrivateFn(){
        privateFn.call(this)
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末搂漠,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子某弦,更是在濱河造成了極大的恐慌桐汤,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件靶壮,死亡現(xiàn)場(chǎng)離奇詭異怔毛,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)腾降,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門馆截,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人蜂莉,你說(shuō)我怎么就攤上這事蜡娶。” “怎么了映穗?”我有些...
    開(kāi)封第一講書人閱讀 156,936評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵窖张,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蚁滋,道長(zhǎng)宿接,這世上最難降的妖魔是什么赘淮? 我笑而不...
    開(kāi)封第一講書人閱讀 56,427評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮睦霎,結(jié)果婚禮上梢卸,老公的妹妹穿的比我還像新娘。我一直安慰自己副女,他們只是感情好蛤高,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著碑幅,像睡著了一般戴陡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上沟涨,一...
    開(kāi)封第一講書人閱讀 49,785評(píng)論 1 290
  • 那天恤批,我揣著相機(jī)與錄音,去河邊找鬼裹赴。 笑死喜庞,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的棋返。 我是一名探鬼主播赋荆,決...
    沈念sama閱讀 38,931評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼懊昨!你這毒婦竟也來(lái)了窄潭?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,696評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤酵颁,失蹤者是張志新(化名)和其女友劉穎嫉你,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體躏惋,經(jīng)...
    沈念sama閱讀 44,141評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡幽污,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了簿姨。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片距误。...
    茶點(diǎn)故事閱讀 38,625評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖扁位,靈堂內(nèi)的尸體忽然破棺而出准潭,到底是詐尸還是另有隱情,我是刑警寧澤域仇,帶...
    沈念sama閱讀 34,291評(píng)論 4 329
  • 正文 年R本政府宣布刑然,位于F島的核電站,受9級(jí)特大地震影響暇务,放射性物質(zhì)發(fā)生泄漏泼掠。R本人自食惡果不足惜怔软,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望择镇。 院中可真熱鬧挡逼,春花似錦、人聲如沸腻豌。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)饲梭。三九已至乘盖,卻和暖如春焰檩,著一層夾襖步出監(jiān)牢的瞬間憔涉,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工析苫, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留兜叨,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓衩侥,卻偏偏與公主長(zhǎng)得像国旷,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子茫死,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • ??ES6中新增了class的定義方法跪但,可以說(shuō)是對(duì)JavaScript這門語(yǔ)言的極大豐富。雖然其本質(zhì)上還是對(duì)象峦萎,但...
    Splendid飛羽閱讀 12,301評(píng)論 1 4
  • 本文為阮一峰大神的《ECMAScript 6 入門》的個(gè)人版提純屡久! babel babel負(fù)責(zé)將JS高級(jí)語(yǔ)法轉(zhuǎn)義,...
    Devildi已被占用閱讀 1,972評(píng)論 0 4
  • class的基本用法 概述 JavaScript語(yǔ)言的傳統(tǒng)方法是通過(guò)構(gòu)造函數(shù)爱榔,定義并生成新對(duì)象被环。下面是一個(gè)例子: ...
    呼呼哥閱讀 4,086評(píng)論 3 11
  • [TOC] 參考阮一峰的ECMAScript 6 入門參考深入淺出ES6 let和const let和const都...
    郭子web閱讀 1,773評(píng)論 0 1
  • 簡(jiǎn)介 類的由來(lái) JavaScript 語(yǔ)言中,生成實(shí)例對(duì)象的傳統(tǒng)方法是通過(guò)構(gòu)造函數(shù)详幽。下面是一個(gè)例子筛欢。 上面這種寫法...
    IT楊閱讀 787評(píng)論 0 2