JavaScript 模式(三)

JS字面量和構(gòu)造函數(shù)


1.總體說明

  • 盡量避免使用構(gòu)造函數(shù)
  • 按需創(chuàng)建對象方式档玻,最適合選擇字面量

2.字面量語法

  • 對象包裝在大括號中
  • 屬性和方法,按照 名稱-值 的方式茫藏,并以逗號區(qū)分误趴。【注意:最后一個逗號不要加务傲,IE不兼容】
  • 用冒號來分割名稱和值
  • 賦值后右大括號后要有分號

格式如下:

   var objectName = {
      propName: value,
      methodName: function(){
          //todo
      }
   };

3.構(gòu)造函數(shù)實質(zhì)

  • JS并沒有類的概念凉当,只是使用函數(shù)實現(xiàn)了類的用法
  • 不要使用 new Object(value) 的構(gòu)造函數(shù)枣申,其動態(tài)決定創(chuàng)建值的類型,會造成意外的后果

構(gòu)造函數(shù)的實質(zhì):

   var Constructor = function(value){
      this.propName = value;
      this.methodName = function(){
           //todo
      }
   }

等價于下述過程(并非實際情況):

   var Constructor = function(value){

      //使用字面量創(chuàng)建空對象
      //var this = {};
 
      //添加屬性和方法
      this.propName = value;
      this.methodName = function(){
           //todo
      }

      //返回該字面量
      //return this;
   }

【說明】

  • 由上述實質(zhì)可以說明看杭,在構(gòu)造函數(shù)中可以返回其他對象值忠藤,用來代替this,但必須是對象值,否則仍然返回this
  • 實際情況中this并非為{}泊窘,而是從其他prototype創(chuàng)建而來
  • 如果構(gòu)造函數(shù)不使用new來操作熄驼,則內(nèi)部的this會指向全局變量,后果意想不到

4.一種安全的構(gòu)造函數(shù)模式

為防止丟失new操作符而導(dǎo)致的構(gòu)造函數(shù)誤用烘豹,可使用以下方式創(chuàng)建構(gòu)造函數(shù):

   var Constructor = function(value){
      
      //自調(diào)用構(gòu)造函數(shù):方式一
      if(!this instanceof Constructor){
         return new Constructor();
      }

      //自調(diào)用構(gòu)造函數(shù):方式二 嚴格模式下不支持
      if(!(this instanceof arguments.callee)){
         return new arguments.callee();
      }

      this.propName = value;
      this.methodName = function(){
           //todo
      }   

   }

5.數(shù)組的構(gòu)造函數(shù)

數(shù)組采用字面量構(gòu)造和構(gòu)造函數(shù)等同:

   var arrayName = new Array(value1, value2, value3 ...);

等同于

   var arrayName = [value1, value2, value3 ...];

【構(gòu)造函數(shù)的問題】

如果使用數(shù)組的構(gòu)造函數(shù)瓜贾,則會有如下問題:

   //生成長度為n的數(shù)組
   var arrayName = new Array(n);
   
   //arrayName[k] 對于數(shù)組中的元素為 undefined

【檢查數(shù)組屬性】

  • 使用typeof操作符,返回object
  • 使用Array.isArray()方法携悯,但部分環(huán)境無法使用
  • 自定義方法:
   if(typeof Array.isArray === "undefined"){
      Array.isArray = function(arg){
         return Object.prototype.toString.call(arg) === "[object Array]";
      }
   }  

6.JSON數(shù)據(jù)

  • JSON和字面量對象的區(qū)別:JSON是鍵-值對祭芦,但鍵名稱必須為字符串(使用引號包裝)
  • JSON數(shù)據(jù)的解析與序列化
  //解析
  var objectName = JSON.parse(jsonString);

  //序列化
  var jsonString = JSON.stringify(objectName);

7.正則表達式

構(gòu)造函數(shù)生成:

  var re = new RegExp(regexString,option);
  //option: "g" "m" "i"組合

【說明】:

  • 正則表達式需要進行轉(zhuǎn)義,難以閱讀
  • 是否使用new操作符都可以

字面量生成:

  var re = /regexString/option
  //option: g m i 組合憔鬼,直接跟在后面

【說明】

  • 在以前的版本中龟劲,一個字面量創(chuàng)建后,后面返回的對象都相同轴或,新版本已經(jīng)更改

8.錯誤對象

內(nèi)置的錯誤對象,均可以通過構(gòu)造函數(shù)創(chuàng)建:

  • Error()
  • SyntaxError()
  • TypeError()
    內(nèi)置對象均有以下兩個屬性:
  • name :錯誤名稱昌跌,一般就是構(gòu)造函數(shù)的名稱
  • message :創(chuàng)建對象時附帶的消息

【自定義錯誤對象】

通過throw拋出任意對象,因此可以創(chuàng)建自定義對象

   try{
      
      throw{
        name:value,
        message:value,
        propName:value,
        methodName:function
      };

   } catch(e){
      //todo
   }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末照雁,一起剝皮案震驚了整個濱河市蚕愤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌饺蚊,老刑警劉巖萍诱,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異污呼,居然都是意外死亡裕坊,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門燕酷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來籍凝,“玉大人,你說我怎么就攤上這事苗缩《伲” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵挤渐,是天一觀的道長苹享。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么得问? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任囤攀,我火速辦了婚禮,結(jié)果婚禮上宫纬,老公的妹妹穿的比我還像新娘焚挠。我一直安慰自己,他們只是感情好漓骚,可當我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布蝌衔。 她就那樣靜靜地躺著,像睡著了一般蝌蹂。 火紅的嫁衣襯著肌膚如雪噩斟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天孤个,我揣著相機與錄音剃允,去河邊找鬼。 笑死齐鲤,一個胖子當著我的面吹牛斥废,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播给郊,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼牡肉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了淆九?” 一聲冷哼從身側(cè)響起统锤,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎吩屹,沒想到半個月后跪另,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拧抖,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡煤搜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了唧席。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片擦盾。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖淌哟,靈堂內(nèi)的尸體忽然破棺而出迹卢,到底是詐尸還是另有隱情,我是刑警寧澤徒仓,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布腐碱,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏症见。R本人自食惡果不足惜喂走,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望谋作。 院中可真熱鬧芋肠,春花似錦、人聲如沸遵蚜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吭净。三九已至睡汹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間寂殉,已是汗流浹背帮孔。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留不撑,地道東北人文兢。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像焕檬,于是被迫代替她去往敵國和親姆坚。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,486評論 2 348

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

  • 第5章 引用類型(返回首頁) 本章內(nèi)容 使用對象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,216評論 0 4
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理实愚,服務(wù)發(fā)現(xiàn)兼呵,斷路器,智...
    卡卡羅2017閱讀 134,629評論 18 139
  • 第一幅圖人物衣服的顏色涂得很失敗 第二幅圖人物腿部曲線畫的不太自然 今天一開始很沒信心腊敲,怕我畫不好人物击喂。可畫著畫著...
    anlence閱讀 179評論 1 1