《JavaScript入門學(xué)習(xí)》之生產(chǎn)環(huán)境中正確使用對(duì)象的姿勢(shì)

先來(lái)看一個(gè)例子

function Person() {
     this.name = 'chengxuyuan';
     this.age = 26;
     this.type = '人類';
     this.eat = function() {
          alert("吃老鼠");
      };
 }
 var p1 = new Person();
 var p2 = new Person();

通過(guò)Person創(chuàng)建了兩個(gè)對(duì)象p1 p2哄啄,里面定義的屬性方法在內(nèi)存里面是兩份。

p1.type == p2.type // false
p1.eat == p2.eat // false

在這個(gè)人類的實(shí)例中姐仅,type是'人類'這個(gè)屬性刊头,new出來(lái)的對(duì)象基本上都是這個(gè)值,
eat這個(gè)函數(shù)也是所有對(duì)象都有的行為佛舱,從業(yè)務(wù)性質(zhì)講是不變的椎例,因此就每次要每次new都占用一份內(nèi)存。
我們應(yīng)該有一種機(jī)制请祖,不論new多少次订歪,某個(gè)類某些屬性方法都共享一份,那么肆捕,前面學(xué)習(xí)的prototype就派上用場(chǎng)了~
因此正確的姿勢(shì)就是這樣:

function Person() {
     this.name = 'chengxuyuan';
     this.age = 26;
     Person.prototype.type = '人類';
     Person.prototype.eat = function () {
           console.log('吃飯');
     };
 }

// 也可以寫在外面動(dòng)態(tài)添加原型類的屬性或者方法
Person.prototype.job = "coding";
Person.prototype.breath = function () {console.log('呼吸'); };

var p1 = new Person();
var p2 = new Person();

這樣p1 刷晋, p2 的type,job屬性,eat眼虱,breath方法喻奥,都指向同一個(gè)內(nèi)存地址。
現(xiàn)在我們可以通過(guò)這種方案隨心所欲的new出對(duì)象捏悬,實(shí)現(xiàn)js里面的面向?qū)ο蟪绦蛟O(shè)計(jì)撞蚕,但通常實(shí)際生產(chǎn)環(huán)境中,我們不經(jīng)常用new的方式創(chuàng)建對(duì)象邮破。例如React Native里面View對(duì)象的源碼(View.js) 里面:

const View = createReactClass({
  displayName: 'View',
  // TODO: We should probably expose the mixins, viewConfig, and statics publicly. For example,
  // one of the props is of type AccessibilityComponentType. That is defined as a const[] above,
  // but it is not rendered by the docs, since `statics` below is not rendered. So its Possible
  // values had to be hardcoded.
  mixins: [NativeMethodsMixin],

  // `propTypes` should not be accessed directly on View since this wrapper only
  // exists for DEV mode. However it's important for them to be declared.
  // If the object passed to `createClass` specifies `propTypes`, Flow will
  // create a static type from it. This property will be over-written below with
  // a warn-on-use getter though.
  // TODO (bvaughn) Remove the warn-on-use comment after April 1.
  propTypes: ViewPropTypes,
  ..................
});

創(chuàng)建對(duì)象的方法是通過(guò)createReactClass({ xx:xx , yy:xx ....});方式诈豌。
下面介紹這樣的創(chuàng)建的對(duì)象姿勢(shì)

最終正確的姿勢(shì)

function Person(props) {
    this.name = props.name || 'people';    // 默認(rèn)值為'匿名'
    this.age = props.grade || 1;      // 默認(rèn)值為1
}

Person.prototype.hello = function () {
    alert('Hello, ' + this.name + '!');
};

function createPerson(props) {
    return new Person(props || {})
}

var p =  createPerson({
   name:'hanxiaoqing'
});

這樣的creat xx函數(shù)不需要new來(lái)調(diào)用,因?yàn)橛行r(shí)候我們會(huì)忘記寫new抒和,會(huì)造成類聲明體內(nèi)部的this找不到指向的對(duì)象矫渔,為undefined,造成問(wèn)題會(huì)很嚴(yán)重摧莽。使用creat xx函數(shù)可以很好的避免這種問(wèn)題庙洼。
還有一個(gè)好處就是參數(shù)非常靈活,不傳值就是聲明時(shí)候的可定制的默認(rèn)值镊辕,如name油够,傳值就覆蓋默認(rèn)值。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末征懈,一起剝皮案震驚了整個(gè)濱河市石咬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卖哎,老刑警劉巖鬼悠,帶你破解...
    沈念sama閱讀 223,126評(píng)論 6 520
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異亏娜,居然都是意外死亡焕窝,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,421評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門维贺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)它掂,“玉大人,你說(shuō)我怎么就攤上這事溯泣∨扒铮” “怎么了?”我有些...
    開封第一講書人閱讀 169,941評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵垃沦,是天一觀的道長(zhǎng)客给。 經(jīng)常有香客問(wèn)我,道長(zhǎng)栏尚,這世上最難降的妖魔是什么起愈? 我笑而不...
    開封第一講書人閱讀 60,294評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮译仗,結(jié)果婚禮上抬虽,老公的妹妹穿的比我還像新娘。我一直安慰自己纵菌,他們只是感情好阐污,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,295評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著咱圆,像睡著了一般笛辟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上序苏,一...
    開封第一講書人閱讀 52,874評(píng)論 1 314
  • 那天手幢,我揣著相機(jī)與錄音,去河邊找鬼忱详。 笑死围来,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的匈睁。 我是一名探鬼主播监透,決...
    沈念sama閱讀 41,285評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼航唆!你這毒婦竟也來(lái)了胀蛮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,249評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤糯钙,失蹤者是張志新(化名)和其女友劉穎粪狼,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體超营,經(jīng)...
    沈念sama閱讀 46,760評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鸳玩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,840評(píng)論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了演闭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片不跟。...
    茶點(diǎn)故事閱讀 40,973評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖米碰,靈堂內(nèi)的尸體忽然破棺而出窝革,到底是詐尸還是另有隱情,我是刑警寧澤吕座,帶...
    沈念sama閱讀 36,631評(píng)論 5 351
  • 正文 年R本政府宣布虐译,位于F島的核電站,受9級(jí)特大地震影響吴趴,放射性物質(zhì)發(fā)生泄漏漆诽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,315評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望厢拭。 院中可真熱鬧兰英,春花似錦、人聲如沸供鸠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,797評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)楞捂。三九已至薄坏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寨闹,已是汗流浹背胶坠。 一陣腳步聲響...
    開封第一講書人閱讀 33,926評(píng)論 1 275
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留繁堡,地道東北人涵但。 一個(gè)月前我還...
    沈念sama閱讀 49,431評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像帖蔓,于是被迫代替她去往敵國(guó)和親矮瘟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,982評(píng)論 2 361

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