<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12
      代碼改變世界

      深入理解JavaScript系列(42):設計模式之原型模式

      2012-04-16 09:11  湯姆大叔  閱讀(13967)  評論(8)    收藏  舉報

      介紹

      原型模式(prototype)是指用原型實例指向創(chuàng)建對象的種類,并且通過拷貝這些原型創(chuàng)建新的對象。

      正文

      對于原型模式,我們可以利用JavaScript特有的原型繼承特性去創(chuàng)建對象的方式,也就是創(chuàng)建的一個對象作為另外一個對象的prototype屬性值。原型對象本身就是有效地利用了每個構造器創(chuàng)建的對象,例如,如果一個構造函數(shù)的原型包含了一個name屬性(見后面的例子),那通過這個構造函數(shù)創(chuàng)建的對象都會有這個屬性。

      在現(xiàn)有的文獻里查看原型模式的定義,沒有針對JavaScript的,你可能發(fā)現(xiàn)很多講解的都是關于類的,但是現(xiàn)實情況是基于原型繼承的JavaScript完全避免了類(class)的概念。我們只是簡單從現(xiàn)有的對象進行拷貝來創(chuàng)建對象。

      真正的原型繼承是作為最新版的ECMAScript5標準提出的,使用Object.create方法來創(chuàng)建這樣的對象,該方法創(chuàng)建指定的對象,其對象的prototype有指定的對象(也就是該方法傳進的第一個參數(shù)對象),也可以包含其他可選的指定屬性。例如Object.create(prototype, optionalDescriptorObjects),下面的例子里也可以看到這個用法:

      // 因為不是構造函數(shù),所以不用大寫
      var someCar = {
      drive: function () { },
      name: '馬自達 3'
      };

      // 使用Object.create創(chuàng)建一個新車x
      var anotherCar = Object.create(someCar);
      anotherCar.name = '豐田佳美';

      Object.create運行你直接從其它對象繼承過來,使用該方法的第二個參數(shù),你可以初始化額外的其它屬性。例如:

      var vehicle = {
      getModel: function () {
      console.log('車輛的模具是:' + this.model);
      }
      };

      var car = Object.create(vehicle, {
      'id': {
      value: MY_GLOBAL.nextId(),
      enumerable: true // 默認writable:false, configurable:false
      },
      'model': {
      value: '福特',
      enumerable: true
      }
      });

      這里,可以在Object.create的第二個參數(shù)里使用對象字面量傳入要初始化的額外屬性,其語法與Object.defineProperties或Object.defineProperty方法類型。它允許您設定屬性的特性,例如enumerable, writable 或 configurable。

      如果你希望自己去實現(xiàn)原型模式,而不直接使用Object.create 。你可以使用像下面這樣的代碼為上面的例子來實現(xiàn):

      var vehiclePrototype = {
      init: function (carModel) {
      this.model = carModel;
      },
      getModel: function () {
      console.log('車輛模具是:' + this.model);
      }
      };


      function vehicle(model) {
      function F() { };
      F.prototype = vehiclePrototype;

      var f = new F();

      f.init(model);
      return f;
      }

      var car = vehicle('福特Escort');
      car.getModel();

      總結

      原型模式在JavaScript里的使用簡直是無處不在,其它很多模式有很多也是基于prototype的,就不多說了,這里大家要注意的依然是淺拷貝和深拷貝的問題,免得出現(xiàn)引用問題。

      同步與推薦

      本文已同步至目錄索引:深入理解JavaScript系列

      深入理解JavaScript系列文章,包括了原創(chuàng),翻譯,轉載等各類型的文章,如果對你有用,請推薦支持一把,給大叔寫作的動力。

      主站蜘蛛池模板: 亚洲另类丝袜综合网| 欧美孕妇乳喷奶水在线观看| 欧美黑人巨大xxxxx| 69天堂人成无码免费视频| 亚洲高清国产自产拍av| 国产精品久久久久久久9999| 国产精品污双胞胎在线观看| 中文人妻无码一区二区三区在线| 国产精品久久国产丁香花| 日韩激情一区二区三区| 日本区二区三区不卡视频| 国产欧美日韩亚洲一区二区三区 | 欧美人成在线播放网站免费| 久久先锋男人AV资源网站| 高潮射精日本韩国在线播放| 丁香婷婷在线观看| 亚洲人成网站观看在线观看 | 国产午夜亚洲精品福利| 18岁日韩内射颜射午夜久久成人| 另类图片亚洲人妻中文无码| 真实国产老熟女无套内射| 国产成人AV男人的天堂| 日韩一区二区大尺度在线| 精品不卡一区二区三区| 久久99国产精品尤物| 日韩国产欧美精品在线| 中文字幕乱码人妻二区三区| 国产精品伦人视频免费看| 乱女伦露脸对白在线播放| 亚洲天堂男人的天堂在线| 在国产线视频A在线视频| 无码A级毛片免费视频下载 | 亚洲精品一区二区妖精| 亚洲欧美综合中文| 精品午夜福利在线视在亚洲| 无遮高潮国产免费观看| 国产精品一二三区久久狼| 色欲综合久久中文字幕网| 国产午夜福利在线视频| 一区二区在线观看 激情| 日本人妻巨大乳挤奶水免费|