JavaScript25

一、構(gòu)造函數(shù)

說(shuō)構(gòu)造函數(shù)的概念之前我們應(yīng)該先了解類的概念寂玲,類與對(duì)象的概念息息相關(guān),我們?cè)谥v對(duì)象的概念的時(shí)候說(shuō)過(guò)梗摇,一只貓是一個(gè)對(duì)象拓哟,一個(gè)人是一個(gè)對(duì)象,一章桌子也是一個(gè)對(duì)象伶授,那么我們平時(shí)說(shuō)的貓断序,人流纹,桌子在沒(méi)有特定指出是哪一個(gè)對(duì)象的時(shí)候,我們其實(shí)說(shuō)的就是類违诗。我們身邊有人類漱凝,貓也是 一個(gè)類,任何有相同屬性和方法的對(duì)象我們都可以稱他們?yōu)橐粋€(gè)類诸迟。

在很多面向?qū)ο笳Z(yǔ)言中都有類的概念茸炒,但是在javascript(es5)中沒(méi)有類。而我們可以通過(guò)構(gòu)造函數(shù)來(lái)模擬一個(gè)類阵苇。

function Cat(){

? ? this.name='miaomiao';

? ? this.age=12;

? ? this.sayName=function(){

? ? ? ? console.log('我們是貓類');

? ? }

}

var cat=new Cat();

console.log(cat.name);

cat.sayName();

構(gòu)造函數(shù)的函數(shù)名首字母大寫(xiě)壁公,可以通過(guò)在函數(shù)中的this為類設(shè)置屬性和方法,我們?cè)谏厦娴拇a中為貓這個(gè)類定義了一個(gè)name屬性绅项,并賦值為"miaomiao"紊册,類創(chuàng)建完成后,我們可以通過(guò)new關(guān)鍵字創(chuàng)建這個(gè)類的實(shí)例快耿。例如cat這個(gè)變量就是Cat類的一個(gè)實(shí)例囊陡。

我們可以通過(guò)傳參的方式,在實(shí)例化對(duì)象的時(shí)候?yàn)閷?duì)象設(shè)置屬性

function Cat(name,age){

? ? this.name=name;

? ? this.age=age;

? ? this.sayName=function(){

? ? ? ? console.log('我是'+this.name);

? ? }

}

var cat=new Cat('mioamiao',12);

cat.sayName();

console.log(cat);

一個(gè)構(gòu)造函數(shù)可以生成多個(gè)對(duì)象的實(shí)例

function Person(name,age){

? ? this.name=name;

? ? this.age=age;

? ? this.say=function(){

? ? ? ? console.log('大家好');

? ? }

}

var lily=Person('lily',12);

var lucy=Person('lucy',13);

console.log(lily);

console.log(lucy);

console.log(lily.say==lucy.say);

一個(gè)構(gòu)造函數(shù)Person生成了兩個(gè)對(duì)象實(shí)例lily和lucy掀亥,并且有兩個(gè)屬性和一個(gè)方法关斜。但是,它們的hobby方法是不一樣的铺浇。也就是說(shuō)痢畜,每當(dāng)你使用new來(lái)調(diào)用構(gòu)造函數(shù)放回一個(gè)對(duì)象實(shí)例的時(shí)候,都會(huì)創(chuàng)建一個(gè)hobby方法鳍侣。這既沒(méi)有必要丁稀,又浪費(fèi)資源,hobby方法完全可以被兩個(gè)對(duì)象實(shí)例共享倚聚。? ? ? ? ?

構(gòu)造函數(shù)的缺點(diǎn)就是:同一個(gè)構(gòu)造函數(shù)的對(duì)象實(shí)例之間無(wú)法共享屬性或方法线衫。

為了解決構(gòu)造函數(shù)的對(duì)象實(shí)例之間無(wú)法共享屬性的缺點(diǎn),js提供了prototype屬性惑折。

//每一個(gè)構(gòu)造函數(shù)都有一個(gè)prototype屬性授账,這個(gè)屬性指向一個(gè)原型對(duì)象,這個(gè)原型對(duì)象上的所有屬性和方法都可以被這個(gè)構(gòu)造函數(shù)的實(shí)例使用

function Person(name,age){

? ? this.name=name;

? ? this.age=age;

}

Person.prototype.hobby=function(){

? ? return 'movie';

}

var girl=new Cat('rose',12);

var boy=new Cat('jack',18);

console.log(girl.hobby==boy.hobby);

//如果將hobby方法放在原型對(duì)象上惨驶,那么兩個(gè)實(shí)例對(duì)象都共享著同一個(gè)方法白热。

二、變量和流量

我們之前一直使用var定義變量粗卜,在ES6版本中屋确,我們可以使用let定義變量,下面我們來(lái)說(shuō)說(shuō)var與let的區(qū)別。

1)塊級(jí)作用域

//S5只有全局作用域和函數(shù)作用域攻臀,沒(méi)有塊級(jí)作用域的概念焕数,這帶來(lái)了很多不合理的場(chǎng)景∨傩ィ看下面的代碼

for(var i = 0;i<10;i++){

? ? console.log(i); // 0-9

}

console.log(i);? ? // 10

//因?yàn)闆](méi)有塊級(jí)作用域堡赔,所以我們?cè)趂or語(yǔ)句的外面仍然能獲取i的值,在實(shí)際開(kāi)發(fā)中设联,這是一個(gè)不可理喻的場(chǎng)景善已,我們希望的是這個(gè)i只在for語(yǔ)句內(nèi)有效,所以再ES6中添加了塊級(jí)作用域的概念仑荐,我們可以用let聲明變量雕拼,問(wèn)題就解決了

for(let i = 0;i<10;i++){

? ? console.log(i); // 0-9

}

console.log(i);? ? // 報(bào)錯(cuò) i is not defined

//因?yàn)橛胠et聲明變量纵东,變量只在塊級(jí)作用域下有效粘招,所以再for語(yǔ)句之外輸出i會(huì)報(bào)錯(cuò)。

2)不存在變量提升

我們使用var定義變量會(huì)發(fā)生“變量提升”偎球,我們來(lái)看下面的代碼

console.log(number);? ? ? ? ? ? //undefied

var number = 100;? ? ? ? ? ? ?

console.log(string);? ? ? ? ? ? //報(bào)錯(cuò)

let string = "hello world";

變量提升會(huì)導(dǎo)致我們?cè)谧兞柯暶髦笆褂米兞恳膊粫?huì)報(bào)錯(cuò)洒扎,但是這個(gè)變量的值是undefined,這是不合理的衰絮,因?yàn)槿晃覀円褂眠@個(gè)變量袍冷,那就應(yīng)該提前聲明,如果沒(méi)有提前聲明猫牡,就應(yīng)該給予錯(cuò)誤提示料滥。所以再ES6中我們使用let聲明變量性穿,如果在聲明變量前使用變量就會(huì)報(bào)錯(cuò)。

關(guān)于報(bào)錯(cuò),有些同學(xué)會(huì)感覺(jué)不報(bào)錯(cuò)要比報(bào)錯(cuò)好带欢,但實(shí)際開(kāi)發(fā)中,如果程序運(yùn)行與我們的語(yǔ)氣不符鼻由,我們更希望看到錯(cuò)誤信息寇仓,這樣有利于我們更快地發(fā)現(xiàn)問(wèn)題。

3)不允許重復(fù)聲明

在ES5中器联,我們可以多次聲明同一個(gè)變量

var a = 10;

var a = 20;

let b = 10;

let b = 20;? //報(bào)錯(cuò)

//但是多次聲明是沒(méi)有意義的二汛,在ES6中,我們使用let聲明變量限制了不能多次聲明拨拓,如果多次聲明同一個(gè)變量回報(bào)錯(cuò)肴颊。

4)常量

在ES6中,不僅有變量渣磷,還增加了常亮的概念苫昌,我們用const聲明常亮,一旦聲明,它的值就不能再改變

const PI = 3.1415926;

PI = 3? ? ? ? ? ? ? ? ? //報(bào)錯(cuò)

我們說(shuō)常亮不能再改變祟身,說(shuō)的是不能重新為這個(gè)常亮賦值奥务,但是如果常亮存儲(chǔ)的是一個(gè)對(duì)象,那我們是可以改變這個(gè)對(duì)象的屬性的

const obj = {name:'小明'};

obj.name = '小紅';

console.log(obj.name);? //小紅

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末袜硫,一起剝皮案震驚了整個(gè)濱河市氯葬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌婉陷,老刑警劉巖帚称,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異秽澳,居然都是意外死亡闯睹,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門担神,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)楼吃,“玉大人,你說(shuō)我怎么就攤上這事妄讯『⑽” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵亥贸,是天一觀的道長(zhǎng)躬窜。 經(jīng)常有香客問(wèn)我,道長(zhǎng)炕置,這世上最難降的妖魔是什么荣挨? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮朴摊,結(jié)果婚禮上默垄,老公的妹妹穿的比我還像新娘。我一直安慰自己仍劈,他們只是感情好厕倍,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著贩疙,像睡著了一般讹弯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上这溅,一...
    開(kāi)封第一講書(shū)人閱讀 49,784評(píng)論 1 290
  • 那天组民,我揣著相機(jī)與錄音,去河邊找鬼悲靴。 笑死臭胜,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播耸三,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼乱陡,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了仪壮?” 一聲冷哼從身側(cè)響起憨颠,我...
    開(kāi)封第一講書(shū)人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎积锅,沒(méi)想到半個(gè)月后爽彤,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缚陷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年适篙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片箫爷。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡嚷节,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蝶缀,到底是詐尸還是另有隱情丹喻,我是刑警寧澤薄货,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布翁都,位于F島的核電站,受9級(jí)特大地震影響谅猾,放射性物質(zhì)發(fā)生泄漏柄慰。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一税娜、第九天 我趴在偏房一處隱蔽的房頂上張望坐搔。 院中可真熱鬧,春花似錦敬矩、人聲如沸概行。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)凳忙。三九已至,卻和暖如春禽炬,著一層夾襖步出監(jiān)牢的瞬間涧卵,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工腹尖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留柳恐,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像乐设,于是被迫代替她去往敵國(guó)和親讼庇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

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

  • 第2章 基本語(yǔ)法 2.1 概述 基本句法和變量 語(yǔ)句 JavaScript程序的執(zhí)行單位為行(line)近尚,也就是一...
    悟名先生閱讀 4,131評(píng)論 0 13
  • (一)函數(shù) 1.函數(shù)基本聲明 function fun([參數(shù)1],[參數(shù)2],...){ 函數(shù)體巫俺; }; 2....
    妖妖靈嘛0閱讀 288評(píng)論 0 0
  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情肿男,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式介汹。簡(jiǎn)單...
    舟漁行舟閱讀 7,724評(píng)論 2 17
  • Scala與Java的關(guān)系 Scala與Java的關(guān)系是非常緊密的!舶沛! 因?yàn)镾cala是基于Java虛擬機(jī)嘹承,也就是...
    燈火gg閱讀 3,424評(píng)論 1 24
  • 對(duì)于韓劇和韓國(guó)電影叹卷,一直提不起什么興趣。覺(jué)得情節(jié)大都拖沓坪它、狗血得厲害骤竹。周六晚上,為了松弛忙碌了一周的神經(jīng)往毡,決定挑部...
    南歌吟閱讀 2,226評(píng)論 30 33