Javascript 類的最佳實(shí)踐

由于已經(jīng)全面轉(zhuǎn)向Typescript,把Javascript的一些實(shí)踐記錄下來(lái)幕屹,防老年癡呆

約定

返回必須是單純數(shù)據(jù)類型满葛,對(duì)象的所有屬性都必須直接包含其中昌罩,例如:

let child = {
    a:1,
    b:2,
    c(){console.log('the func')}
}

好處:

  1. 編輯器可以識(shí)別所有屬性阱穗,方便開(kāi)發(fā)


    當(dāng)然jsx的props也可以識(shí)別饭冬,這里就不另貼圖了
  2. 可預(yù)期對(duì)象的結(jié)果

屬性結(jié)構(gòu)的類

思路取自阮一峰的Javascript定義類(class)的三種方法中的第三個(gè)方法,添加了方法重載的實(shí)現(xiàn)方式揪阶,并且返回類型約定為IDE容易識(shí)別的結(jié)構(gòu)形態(tài)

最基礎(chǔ)的類昌抠,和其實(shí)例化、調(diào)用函數(shù)

let Dog = {
    init(){
        let child = {
            name: 'the dog',
            say(){
                console.log('Wang!Wang!!!')
            }
        }
        return child
    }
}
let dog = Dog.init()
dog.say()

帶有靜態(tài)變量的類

let Dog = {
    staticAge: 10,
    init(name){
        let _this = this
        let child = {
            name: name || 'the dog',
            say(){
                console.log(`I'm ${_this.staticAge}, ${child.name}`)
            }
        }
        return child
    }
}
let dog1 = Dog.init('red')
let dog2 = Dog.init('yellow')
let dog3 = Dog.init('bbb')
dog1.say()
dog2.say()
Dog.staticAge = 20
dog1.say()
dog2.say()

類的繼承鲁僚, 方法重載炊苫, 子屬性裁厅,父屬性調(diào)用

let Dog = {
    init(name){
        let child = {
            name: name || 'the dog',
            say(){
                console.log('Wang!Wang!!!')
            }
        }
        return child
    }
}

let WolfDog = {
    init(name, age) {
        let father = Dog.init(name)
        let child = {
            name: 'mini ' + name,
            age: age || 10,
            say(){
                //函數(shù)重載
                father.say()
                console.log('Wooooooo!!!')
            },
            hello(){
                //讀取子熟悉和父屬性
                console.log(`I'm ${child.name}, my father's is ${father.name}`)
            }
        }
        return Object.assign(Dog.init(name), child)
    }
}

let wolf = WolfDog.init('tim', 50)
wolf.say() //Wang!Wang!!! Wooooooo!!!
wolf.hello() //I'm mini tim, my father's is tim

方法結(jié)構(gòu)的類(優(yōu)勢(shì)寫(xiě)起來(lái)美觀,但是不推薦劝评,原因最后有寫(xiě))

這個(gè)思路和屬性結(jié)構(gòu)的類是一樣的姐直,都是在內(nèi)部創(chuàng)建一個(gè)臨時(shí)的子對(duì)象倦淀,然后返回此子對(duì)象

約定:類的首字母必須大寫(xiě)蒋畜,以區(qū)分類和函數(shù)

類的創(chuàng)建,實(shí)例化撞叽,調(diào)用函數(shù)

let Dog = function(name) {
    let _this = this
    let child = {
        name: name || 'the Dog',
        say(){
            console.log(child.name + ': wang!wang!!!')
        }
    }
    return child
}

let dog1 = Dog('redDog')
let dog2 = Dog('yelloDow')
dog1.say()  //redDog: wang!wang!!!
dog2.say()  //yelloDow: wang!wang!!!

類的靜態(tài)屬性

let Dog = function(name) {
    this.staticAge = 10
    let _this = this
    let child = {
        name: name || 'the Dog',
        say(){
            console.log(child.name + ': wang!wang!!!')
            console.log('I am ' + _this.staticAge)
        },
        setStaticAge(newAge) {
            _this.staticAge = newAge
        }
    }
    return child
}

let dog1 = Dog('redDog')
let dog2 = Dog('yelloDow')
dog1.say()  //redDog: wang!wang!!!
dog1.setStaticAge(20)
dog2.say()  //yelloDow: wang!wang!!!

類的繼承姻成, 方法重載, 子屬性愿棋,父屬性調(diào)用

let Dog = function(name){
    let child = {
        name: name,
        say(){
            console.log(child.name + ': wang!wang!!!')
        }
    }
    return child
}

let WolfDog = function(name, age) {
    let father = Dog(name)
    let child = {
        name: 'mini' + father.name,
        age: age,
        say(){
            father.say()
            console.log(child.name + ': wooooooo!!!')
        }
    }
    return Object.assign(Dog(name), child)
}

let wolf = WolfDog('blueWolf', 15)
wolf.say() //blueWolf: wang!wang!!!, miniblueWolf: wooooooo!!!
console.log(wolf.name) //miniblueWolf

不推薦的理由

雖然方法結(jié)構(gòu)的類更加美觀科展,但是現(xiàn)在發(fā)現(xiàn)無(wú)法有多個(gè)構(gòu)造函數(shù),而屬性結(jié)構(gòu)的類可以有多個(gè)構(gòu)造函數(shù)

//熟悉Objective-C的朋友應(yīng)該很熟悉這種工廠方法:
Dog.init('redDog')
Dog.initWithMagic('lightning',1000)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末糠雨,一起剝皮案震驚了整個(gè)濱河市才睹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌甘邀,老刑警劉巖琅攘,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異松邪,居然都是意外死亡坞琴,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)逗抑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)剧辐,“玉大人,你說(shuō)我怎么就攤上這事邮府∮兀” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵褂傀,是天一觀的道長(zhǎng)忍啤。 經(jīng)常有香客問(wèn)我,道長(zhǎng)紊服,這世上最難降的妖魔是什么檀轨? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮欺嗤,結(jié)果婚禮上参萄,老公的妹妹穿的比我還像新娘。我一直安慰自己煎饼,他們只是感情好讹挎,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般筒溃。 火紅的嫁衣襯著肌膚如雪马篮。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天怜奖,我揣著相機(jī)與錄音浑测,去河邊找鬼。 笑死歪玲,一個(gè)胖子當(dāng)著我的面吹牛迁央,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播滥崩,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼岖圈,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了钙皮?” 一聲冷哼從身側(cè)響起蜂科,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎短条,沒(méi)想到半個(gè)月后导匣,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡慌烧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年逐抑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屹蚊。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡厕氨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出汹粤,到底是詐尸還是另有隱情命斧,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布嘱兼,位于F島的核電站国葬,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏芹壕。R本人自食惡果不足惜汇四,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望踢涌。 院中可真熱鬧通孽,春花似錦、人聲如沸睁壁。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至行剂,卻和暖如春秕噪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背厚宰。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工腌巾, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人固阁。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓壤躲,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親备燃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

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