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

js使用原型對象(prototype)需要注意的地方

 更新時間:2017年08月28日 15:38:05   作者:ghostwu  
這篇文章主要為大家詳細介紹了js使用原型對象(prototype)需要注意的地方,具有一定的參考價值,感興趣的小伙伴們可以參考一下

我們先來一個簡單的構(gòu)造函數(shù)+原型對象的小程序

function CreateObj( uName, uAge ) {
      this.userName = uName;
      this.userAge = uAge;
    }
    CreateObj.prototype.showUserName = function () {
      return this.userName;
    }
    CreateObj.prototype.showUserAge = function () {
      return this.userAge;
    }

這個程序,沒有什么問題,但是非常的冗余,每次擴展一個方法,都要寫一次原型對象,我們可以把原型對象prototype當做一個字面量對象,所有的方法都在字面量對象中擴展,可以達到同樣的效果:

CreateObj.prototype = {
      showUserAge : function(){
        return this.userAge;
      },
      showUserName : function(){
        return this.userName;
      },
    }
    var obj1 = new CreateObj( 'ghostwu', 22 );
    var obj2 = new CreateObj( '衛(wèi)莊', 24 );
    console.log( obj1.showUserName(), obj1.showUserAge() ); //ghostwu 22
    console.log( obj2.showUserName(), obj2.showUserAge() ); //衛(wèi)莊 24

但是這種原型(prototype)對象的寫法,屬于重寫了CreateObj的默認原型對象,造成的第一個問題就是constructor不再指向CreateObj.

沒有重寫之前,constructor指向CreateObj

function CreateObj( uName, uAge ) {
      this.userName = uName;
      this.userAge = uAge;
    }
    CreateObj.prototype.showUserName = function () {
      return this.userName;
    }
    CreateObj.prototype.showUserAge = function () {
      return this.userAge;
    }
    console.log( CreateObj.prototype.constructor === CreateObj ); //true

重寫之后,constructor指向Object

CreateObj.prototype = {
      showUserAge : function(){
        return this.userAge;
      },
      showUserName : function(){
        return this.userName;
      },
    }
    console.log( CreateObj.prototype.constructor === CreateObj ); //false
    console.log( CreateObj.prototype.constructor === Object ); //true

所以說,constructor不能準確的標識對象,因為他會被修改

我們之前寫的程序,基本都是在原型對象(prototype)上擴展完了方法之后,再實例化對象,我們看下,先實例化對象,再在原型對象(prototype)上擴展函數(shù),

實例對象是否能正常的調(diào)用到擴展的方法?

function CreateObj( uName, uAge ) {
      this.userName = uName;
      this.userAge = uAge;
    }
    var obj1 = new CreateObj( 'ghostwu', 22 );
    CreateObj.prototype.showUserName = function(){
      return this.userName;
    }
    console.log( obj1.showUserName() ); //ghostwu

可以正常調(diào)用,但是,如果原型對象是重寫的,就調(diào)用不到了

function CreateObj( uName, uAge ) {
      this.userName = uName;
      this.userAge = uAge;
    }
    var obj1 = new CreateObj( 'ghostwu', 22 );
    CreateObj.prototype = {
      showUserName : function(){
        return this.userName;
      }
    }
    console.log( obj1.showUserName() ); //報錯

因為重寫了原型對象之后,同時實例化又是在重寫之前發(fā)生的,所以實例的隱式原型__proto__不會指向重寫的原型對象,所以就調(diào)用不到另一個問題,如果在原型對象(prototype)上有引用類型,千萬小心,因為多個實例共用原型對象,只要有一個實例改變了引用類型的值,其他實例全部會收到改變之后的結(jié)果。

function CreateObj(){}
    CreateObj.prototype = {
      name : 'ghostwu',
      skills : [ 'php', 'javascript', 'linux' ]
    };
    var obj1 = new CreateObj();
    obj1.skills.push( 'python' );
    var obj2 = new CreateObj();
    console.log( obj2.skills ); //'php', 'javascript', 'linux', 'python'

原型對象(prototype)的共享特性,可以很方便的為一些內(nèi)置的對象擴展一些方法,比如,數(shù)組去重復(fù)

Array.prototype.unique = function(){
      var res = [];
      for( var i = 0, len = this.length; i < len; i++ ){
        if( res.indexOf( this[i] ) == -1 ) {
          res.push( this[i] ); 
        }
      }
      return res;
    }
    var arr = [ 10, 20, 30, 20, 30, 20, 40, 20 ];
    console.log( arr.unique() ); //10, 20, 30, 40

但是,不要隨便往內(nèi)置的對象上面擴展方法,在多人協(xié)作開發(fā),很容易產(chǎn)生覆蓋,以及污染。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 本地存儲localStorage用法詳解

    本地存儲localStorage用法詳解

    這篇文章主要為大家詳細介紹了本地存儲localStorage的用法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 詳解JavaScript前端如何有效處理本地存儲和緩存

    詳解JavaScript前端如何有效處理本地存儲和緩存

    前端本地存儲和緩存的處理是一種重要的技術(shù),它可以幫助改善應(yīng)用程序的性能和用戶體驗,下面是小編整理的一些處理前端本地存儲和緩存的常用方法,希望對大家有所幫助
    2023-11-11
  • JavaScript中如何跳出forEach循環(huán)代碼示例

    JavaScript中如何跳出forEach循環(huán)代碼示例

    循環(huán)遍歷一個元素是開發(fā)中最常見的需求之一,下面這篇文章主要給大家介紹了關(guān)于JavaScript中如何跳出forEach循環(huán)的相關(guān)資料,文章通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • JavaScript實現(xiàn)選項卡效果的分析及步驟

    JavaScript實現(xiàn)選項卡效果的分析及步驟

    這篇文章主要給大家介紹了關(guān)于JavaScript實現(xiàn)選項卡效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用JavaScript具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-04-04
  • JS用斜率判斷鼠標進入DIV四個方向的方法

    JS用斜率判斷鼠標進入DIV四個方向的方法

    在網(wǎng)上去搜判斷鼠標移入div移入移出的方法大同小異,下面小編給大家分享一篇文章關(guān)于js判斷鼠標進入div方向的代碼,感興趣的朋友一起看看吧
    2016-11-11
  • js實現(xiàn)網(wǎng)頁圖片延時加載 提升網(wǎng)頁打開速度

    js實現(xiàn)網(wǎng)頁圖片延時加載 提升網(wǎng)頁打開速度

    這篇文章主要為大家介紹了js實現(xiàn)網(wǎng)頁圖片延時加載,提升網(wǎng)頁打開速度,感興趣的小伙伴們可以參考一下
    2016-01-01
  • javascript中的with語句學習筆記及用法

    javascript中的with語句學習筆記及用法

    在本篇文章里小編給大家分享的是關(guān)于javascript中的with語句學習筆記及用法,有需要的朋友們可以學習下。
    2020-02-02
  • 詳解如何讓JavaScript代碼不可斷點

    詳解如何讓JavaScript代碼不可斷點

    這篇文章主要為大家詳介紹了如何讓JavaScript代碼不可斷點,文中的示例代碼講解詳細,對我們學習JavaScript有一定幫助,感興趣的可以了解一下
    2022-08-08
  • JavaScript中改變this指向的三種方式總結(jié)

    JavaScript中改變this指向的三種方式總結(jié)

    this?指向的值是可以通過手動方式去改變的,比如call、bind、apply方法,本文主要為大家介紹了這三種方式的具體實現(xiàn)步驟,需要的可以參考下
    2023-12-12
  • JavaScript實現(xiàn)滑塊驗證案例

    JavaScript實現(xiàn)滑塊驗證案例

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)滑塊驗證案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評論