亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

簡單理解JavaScript中的封裝與繼承特性

 更新時間:2016年03月19日 15:07:36   作者:sjpsega  
這篇文章主要介紹了JavaScript中的封裝與繼承特性,封裝與繼承是基于對象編程概念中的基本特性,需要的朋友可以參考下

JavaScript中的封裝
封裝簡單地說就是讓外界只能訪問對象的共有變量和函數(shù),隱藏細節(jié)和數(shù)據(jù)。
js中有三種方法創(chuàng)建對象,分別為門戶大開型、用命名規(guī)范區(qū)分私有變量、閉包創(chuàng)建真正的私有變量三種。
1.門戶大開型,是實現(xiàn)對象的最基礎(chǔ)的方法,所有方法與變量都是共有的外界可以訪問。

var Book = function(name){ 
  if(this.check(name)){ 
    console.log("error"); 
    throw new Error("name null"); 
  } 
  this.name = name; 
} 
Book.prototype = { 
  check:function(name){ 
    if(!name){ 
      return true; 
    } 
  }, 
  getName:function(){ 
    return this.name; 
  } 
} 
 
var book = new Book("哈哈"); 
//output:哈哈 哈哈 
console.log(book.name,book.getName()); 

這個例子是門戶大開型的典型,外界能直接訪問對象的屬性和方法??梢宰⒁獾綄傩院妥兞慷加?this"來創(chuàng)建。
 
2.用命名規(guī)范區(qū)分私有變量,該方法是門戶大開型的優(yōu)化版本,只不過是在私有變量或方法前面用"_"區(qū)分,如果有程序員有意使用_getName()的方法來調(diào)用方法,還是無法阻止的,不是真正地將變量隱藏。
 
3.閉包創(chuàng)建真正的私有變量,該方法利用js中只有函數(shù)具有作用域的特性,在構(gòu)造函數(shù)的作用域中定義相關(guān)變量,這些變量可以被定義域該作用域中的所有函數(shù)訪問。

var Book2 = function(name){ 
  if(check(name)){ 
    console.log("error"); 
    throw new Error("name null"); 
  } 
  name = name; 
  function check(name){ 
    if(!name){ 
      return true; 
    } 
  } 
  this.getName = function(){ 
    return name; 
  } 
} 
Book2.prototype = { 
  display:function(){ 
    //無法直接訪問name 
    return "display:"+this.getName(); 
  } 
} 
var book2 = new Book2("哈哈"); 
//output:undefined "哈哈" "display:哈哈" 
console.log(book2.name,book2.getName(),book2.display()); 

 可以看到,這個例子中的結(jié)果,直接訪問name會返回undefined的結(jié)果??梢钥吹竭@個例子與門戶大開型的區(qū)別,門戶大開型中的變量使用"this"來創(chuàng)建,而這個例子中使用var來創(chuàng)建,check函數(shù)也是如此,使得name與check函數(shù)只能在構(gòu)造函數(shù)的作用域中訪問,外界無法直接訪問。
該方法解決了前兩種方法的問題,但是也有一定的弊端。在門戶大開型對象創(chuàng)建模式中,所有方法都創(chuàng)建在原型對象中,因此不管生成多少對象實例,這些方法在內(nèi)存中只存在一份,而采用該方法,每生成一個新的對象都會為每個私有變量和方法創(chuàng)建一個新的副本,故會耗費更多的內(nèi)存。

JavaScript中的繼承
Book基類:

var Book = function(name){ 
  if(this.check(name)){ 
    console.log("error"); 
    throw new Error("name null"); 
  } 
  this.name = name; 
} 
Book.prototype = { 
  check:function(name){ 
    if(!name){ 
      return true; 
    } 
  }, 
  getName:function(){ 
    return this.name; 
  } 
} 

繼承方法:

function extend(subClz,superClz){ 
var F = function(){} 
F.prototype = superClz.prototype; 
subClz.prototype = new F(); 
subClz.prototype.constructor = subClz; 
subClz.superClass = superClz.prototype; 
if(superClz.prototype.constructor == Object.prototype.constructor){ 
  superClz.prototype.constructor = superClz; 
} 

 
使用空函數(shù)F作為橋接,可以避免直接實例化父類時調(diào)用父類的構(gòu)造函數(shù)帶來額外開銷,而且當(dāng)父類的構(gòu)造函數(shù)有參數(shù)時,想直接通過subClass.prototype = new superClass();實現(xiàn)父類構(gòu)造函數(shù)的調(diào)用和原型鏈的繼承是不行的。

subClz.superClass = superClz.prototype; 
if(superClz.prototype.constructor == Object.prototype.constructor){ 
  superClz.prototype.constructor = superClz; 
} 

 
添加這三句可以避免子類繼承父類寫B(tài)ook.call(this,name);而是簡單地寫ArtBook.superClass.Constructor.call(this,name)便能實現(xiàn)。
并且在子類重寫父類方法的時候,可以調(diào)用到父類的方法:

ArtBook.prototype.getName = functiion(){ 
  return ArtBook.superClass.getName.call(this) + "!!!"; 
} 

ArtBook子類:

var ArtBook = function(name,price){ 
  ArtBook.superClass.Constructor.call(this,name); 
  this.price = price; 
} 
extend(ArtBook,Book); 
ArtBook.prototype.getPrice = function(){ 
    return this.price; 
} 
ArtBook.prototype.getName = function(){ 
   return ArtBook.superClass.getName.call(this)+"!!!"; 
 } 

相關(guān)文章

  • 淺談JavaScript function函數(shù)種類

    淺談JavaScript function函數(shù)種類

    這篇文章主要介紹了JavaScript function函數(shù)種類,包括普通函數(shù)、匿名函數(shù)、閉包函數(shù)、十分的全面,并附上了示例,這里推薦給大家,希望對大家能有所幫助。
    2014-12-12
  • 簡單談?wù)凧avascript函數(shù)中的arguments

    簡單談?wù)凧avascript函數(shù)中的arguments

    在JavaScript中,arguments對象是比較特別的一個對象,實際上是當(dāng)前函數(shù)的一個內(nèi)置屬性。下面這篇文章主要介紹了關(guān)于Javascript函數(shù)中的arguments面貌以及如何轉(zhuǎn)化為數(shù)組的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • window.open的功能全解析

    window.open的功能全解析

    window.open的功能全解析...
    2006-10-10
  • 實例解析JS布爾對象的toString()方法和valueOf()方法

    實例解析JS布爾對象的toString()方法和valueOf()方法

    這篇文章主要介紹了JS的布爾對象的toString()方法和valueOf()方法,是JavaScript入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-10-10
  • 關(guān)于js中alert彈出窗口文本換行問題簡單詳細說明

    關(guān)于js中alert彈出窗口文本換行問題簡單詳細說明

    js中alert彈出窗口文本換行是一個小問題,本人很是郁悶,于是搜集整理下,曬出來和大家分享
    2012-12-12
  • 詳解javascript設(shè)計模式三:代理模式

    詳解javascript設(shè)計模式三:代理模式

    這篇文章主要介紹了javascript設(shè)計模式三:代理模式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • javascript冒泡排序小結(jié)

    javascript冒泡排序小結(jié)

    冒泡排序由于比較簡單和容易理解,往往會成為人們首先想到的排序算法。最基本的想法就是在一次里面比較兩個數(shù)字,并且確保他們在移動到其他項目之前有一個正確的順序。在每一關(guān)結(jié)束,有價值的“排序”到正確的位置,最終只留下其他項目排序。
    2016-04-04
  • 全面了解JavaScript的數(shù)據(jù)類型轉(zhuǎn)換

    全面了解JavaScript的數(shù)據(jù)類型轉(zhuǎn)換

    下面小編就為大家?guī)硪黄媪私釰avaScript的數(shù)據(jù)類型轉(zhuǎn)換。小編覺得挺不錯的,現(xiàn)在就分享給大家看,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • 經(jīng)常用到的JavasScript事件的翻譯

    經(jīng)常用到的JavasScript事件的翻譯

    經(jīng)常用到的JavasScript事件的翻譯...
    2007-04-04
  • window.onload和$(function(){})的區(qū)別介紹

    window.onload和$(function(){})的區(qū)別介紹

    window.onload和$(function(){})有什么區(qū)別。window.onload表示頁面加載完了后(包括dom和js),再執(zhí)行函數(shù)里面的內(nèi)容,感興趣的朋友可以了解下
    2013-10-10

最新評論