欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript oop設(shè)計(jì)模式 面向?qū)ο缶幊毯唵螌?shí)例介紹

 更新時(shí)間:2016年12月13日 11:36:00   投稿:lqh  
這篇文章主要介紹了Javascript oop設(shè)計(jì)模式 面向?qū)ο缶幊毯唵螌?shí)例介紹的相關(guān)資料,這里附有實(shí)例代碼幫助大家學(xué)習(xí)理解,需要的朋友可以參考下

Javascript oop設(shè)計(jì)模式 面向?qū)ο缶幊?/strong>

最初我們寫js代碼的時(shí)候是這么寫

 function checkName(){
    //驗(yàn)證姓名
  }

  function checkEmail(){
    //驗(yàn)證郵箱
  }

  function checkPassword(){
    //驗(yàn)證密碼
  }

這種方式會造成全局變量的嚴(yán)重污染,再過渡到

var checkObject = {

  checkName : function(){};
  checkEmail: function(){};
  checkPassword: funcion(){}; 

}

//也可如此寫
var checkObject = {} // || function(){}
checkObject.checkName = function(){};
checkObject.checkEmail = function(){};
checkObject.checkPassword = function(){};


//以上這兩種寫法不能復(fù)制一份,也就是說在new 方法創(chuàng)建新的對象的時(shí)候,新對象不能繼承這些方法

以上是直接使用,而不是新建對象復(fù)制一份的,復(fù)制一份的話可以這么寫

var checkObject = function(){

    return {
      checkName:function(){},
      checkEmail:function(){},
      checkPassword:function(){}
    }
  }
//使用的時(shí)候 可以

var a = checkObject();
a.checkName();



這么寫可以實(shí)現(xiàn)對象的復(fù)制 但是這不符合面向?qū)ο?,新?chuàng)建的類和checkObject 沒有任何關(guān)系
于是我們可以采用構(gòu)造函數(shù)的方式書寫代碼

  var checkObject = function(){
    this.checkName = function(){}
    this.checkEmail = function(){}
    this.checkPassword = function(){}
  }
//像這樣我們便可以用CheckObject 來創(chuàng)建新的對象了,通過new 來創(chuàng)建對象,創(chuàng)建出來的每個(gè)對象都會對this上的屬性進(jìn)行復(fù)制,但是這么做的話,每次都會有相對較大消耗,對于共有的方法,我們可以放在對象的原型上

var checkObject = function(){};
checkObject.prototype.checkName = function(){};
//...


//這樣寫要將prototype 書寫很多遍 ,所以我們可以這么寫,并實(shí)現(xiàn)鏈?zhǔn)秸{(diào)用,將this返回

var checkObject = function(){};
checkObject.prototype={
  checkName:function(){
    //驗(yàn)證姓名
    return this;
  },

  checkEmail:function(){
    //驗(yàn)證郵箱
    return this
  },

  checkPassword:function(){
    //驗(yàn)證密碼
    return this;
  }  

}

// 這兩種方式不可混用,否則后邊會覆蓋前邊,此時(shí)我們調(diào)用只需

new checkObject().checkName().checkEmail().checkPassword();

下面再來介紹一下面向?qū)ο蠛兔嫦蜻^程兩種編程方式 .page 10

多個(gè)function 書寫的方式是一種面向過程書寫代碼的實(shí)現(xiàn)方式,添加了很多全局變量而且不利于別人復(fù)用,在別人使用時(shí)你也不可修改,我們可以改用面向?qū)ο蠓绞絹碇貙?,我們把需求抽成一個(gè)對象,這個(gè)對象稱之為類,面向?qū)ο笠粋€(gè)重要特點(diǎn)就是封裝,將屬性和方法封裝在一個(gè)對象中,就像將物品放在一個(gè)旅行箱中,這樣不管是使用和管理我們都方便,(雖然有時(shí)候感覺直接拿在外邊擺放也很方便,但是東西一多便不利于管理)

  var Book = (function () {
    //靜態(tài)私有變量
    var bookNum = 0;
    //靜態(tài)私有方法
    function checkBook() {
    }

    //返回構(gòu)造函數(shù)
    return function (newId, newName, newPrice) {
      //私有變量
      var name, price;
      //私有方法
      function checkId(id) {
      }
      //特權(quán)方法
      this.getPrice = function () {
      };
      this.getName = function () {
      };
      this.setName = function (name) {
        this.name = name
      };
      this.setPrice = function () {
      };
      //公有屬性
      this.id = newId;
      //公有方法
      this.copy = function () {
      };
      bookNum++;
      if (bookNum > 100)
        throw new Error('oop javascript');

      //構(gòu)造器 實(shí)例化過程中被調(diào)用的方法
      this.setName(name);
      this.setPrice(price);

    }
  })();

  Book.prototype = {
    //靜態(tài)公有屬性
    isJSBook: false,
    //靜態(tài)公有方法
    display: function () {
    }

  };
  //對比Java 別被js 起的這些名字弄混了 其實(shí)Js 就模仿了一個(gè)New 其他的跟Java基本一樣 類 全局變量 方法 有自己的理解比較好 以前未想明白
  // java 為什么那么些

//為了看起來更像一個(gè)類 我們將原型上的方法 寫到類里邊

 var Book = (function () {
    //靜態(tài)私有變量
    var bookNum = 0;
    //靜態(tài)私有方法
    function checkBook() {
    }

    //返回構(gòu)造函數(shù)
     function _Book(newId, newName, newPrice) {
      //私有變量
      var name, price;
      //私有方法
      function checkId(id) {
      }
      //特權(quán)方法
      this.getPrice = function () {
      };
      this.getName = function () {
      };
      this.setName = function (name) {
        this.name = name
      };
      this.setPrice = function () {
      };
      //公有屬性
      this.id = newId;
      //公有方法
      this.copy = function () {
      };
      bookNum++;
      if (bookNum > 100)
        throw new Error('oop javascript');

      //構(gòu)造器 實(shí)例化過程中被調(diào)用的方法
      this.setName(name);
      this.setPrice(price);

    }
    _Book.prototype = {
      //靜態(tài)公有屬性
      isJSBook: false,
      //靜態(tài)公有方法
      display: function () {
      }

    };
    return _Book;
  })();


下面再介紹一種創(chuàng)建對象的安全模式   

//注意 執(zhí)行new Book 方法之前 this.title 會先執(zhí)行一次
  var Book = function (title) {
    if (this instanceof Book) {
      alert(1);
      this.title = title;
    }else{
      return new Book(title);
    }
  };

  var book = new Book('js');
  alert(book.title);

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

  • js實(shí)現(xiàn)鼠標(biāo)滑動到某個(gè)div禁止?jié)L動

    js實(shí)現(xiàn)鼠標(biāo)滑動到某個(gè)div禁止?jié)L動

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)鼠標(biāo)滑動到某個(gè)div禁止?jié)L動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 使用js獲取當(dāng)前年月日的方法及格式整理匯總

    使用js獲取當(dāng)前年月日的方法及格式整理匯總

    很多時(shí)候我們需要在前臺獲取當(dāng)前日期,下面這篇文章主要給大家介紹了關(guān)于使用js獲取當(dāng)前年月日的方法及格式整理的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • ejs v9 javascript模板系統(tǒng)

    ejs v9 javascript模板系統(tǒng)

    我的模板系統(tǒng)升一下級, 繼續(xù)在新公司里面用。 現(xiàn)在幾在互聯(lián)網(wǎng)公司沒有不用javascript模板了, 什么TX, 百度, 新浪, 360什么的, 最后瀑布流的流行, 里面又有許多用到模板
    2012-03-03
  • 微信小程序模版渲染詳解

    微信小程序模版渲染詳解

    這篇文章主要為大家詳細(xì)介紹了微信小程序模版渲染的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 使用webpack將ES6轉(zhuǎn)化ES5的實(shí)現(xiàn)方法

    使用webpack將ES6轉(zhuǎn)化ES5的實(shí)現(xiàn)方法

    這篇文章主要介紹了使用webpack將ES6轉(zhuǎn)化ES5的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • JS針對Array的各種操作匯總

    JS針對Array的各種操作匯總

    這篇文章主要為大家詳細(xì)介紹了JS針對Array的各種操作,如何創(chuàng)建Array,數(shù)組的一些簡單和基本的操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • JavaScript實(shí)現(xiàn)動態(tài)增刪表格的方法

    JavaScript實(shí)現(xiàn)動態(tài)增刪表格的方法

    本篇文章主要介紹了JavaScript實(shí)現(xiàn)動態(tài)增刪表格,可以實(shí)現(xiàn)表格增加和刪除數(shù)據(jù)的功能,非常具有實(shí)用價(jià)值,有興趣的可以了解一下
    2017-03-03
  • 前端防止用戶重復(fù)提交js實(shí)現(xiàn)代碼示例

    前端防止用戶重復(fù)提交js實(shí)現(xiàn)代碼示例

    這篇文章主要給大家介紹了關(guān)于前端防止用戶重復(fù)提交js實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧
    2018-09-09
  • JS獲取當(dāng)前日期和時(shí)間的簡單實(shí)例

    JS獲取當(dāng)前日期和時(shí)間的簡單實(shí)例

    這篇文章主要介紹了JS獲取當(dāng)前日期和時(shí)間的簡單實(shí)例,有需要的朋友可以參考一下
    2013-11-11
  • 兩個(gè)數(shù)組去重的JS代碼

    兩個(gè)數(shù)組去重的JS代碼

    這篇文章主要介紹了兩個(gè)數(shù)組去重的JS代碼,有需要的朋友可以參考一下
    2013-12-12

最新評論