淺析JS原型繼承與類的繼承
來源:易賢網(wǎng) 閱讀:912 次 日期:2016-07-08 14:27:11
溫馨提示:易賢網(wǎng)小編為您整理了“淺析JS原型繼承與類的繼承”,方便廣大網(wǎng)友查閱!

下面小編就為大家?guī)硪黄獪\析JS原型繼承與類的繼承。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。

我們先看JS類的繼承

<!DOCTYPE html>

<html>

<head>

  <meta charset="UTF-8">

    <title>JS類的繼承</title>

</head>

<body>

  /* -- 類式繼承 -- */

  <script type="text/javascript">

  //先聲明一個(gè)超類

  var Animal = function(name) {

      this.name = name;

    }

    //給這個(gè)超類的原型對(duì)象上添加方法

  Animal.prototype.Eat = function() {

    console.log(this.name + " Eat");

  };

  //實(shí)例化這個(gè)超

  var a = new Animal("Animal");

  //再創(chuàng)建構(gòu)造函數(shù)對(duì)象類

  var Cat = function(name, sex) {

      //這個(gè)類中要調(diào)用超類Animal的構(gòu)造函數(shù),并將參數(shù)name傳給它

      Animal.call(this, name);

      this.sex = sex;

    }

    //這個(gè)子類的原型對(duì)象等于超類的實(shí)例

  Cat.prototype = new Animal();

  //因?yàn)樽宇惖脑蛯?duì)象等于超類的實(shí)例,所以prototype.constructor這個(gè)方法也等于超類構(gòu)造函數(shù)

  console.log(Cat.prototype.constructor);

  //這個(gè)是Animal超類的引用,所以要從新賦值為自己本身

  Cat.prototype.constructor = Cat;

  console.log(Cat.prototype.constructor);

  //子類本身添加了getSex 方法

  Cat.prototype.getSex = function() {

      return this.sex;

    }

    //實(shí)例化這個(gè)子類

  var _m = new Cat('cat', 'male');

  //自身的方法

  console.log(_m.getSex()); //male

  //繼承超類的方法

  console.log(_m.Eat()); //cat

  </script>

</body>

</html>

我們?cè)倏碕S原型繼承

<!DOCTYPE html>

<html>

<head>

  <meta charset="UTF-8">

  <title>JS原型繼承</title>

</head>

<body>

  <!--原型繼承-->

  <script type="text/javascript">

  //clone()函數(shù)用來創(chuàng)建新的類Person對(duì)象

  var clone = function(obj) {

    var _f = function() {};

    //這句是原型式繼承最核心的地方,函數(shù)的原型對(duì)象為對(duì)象字面量

    _f.prototype = obj;

    return new _f;

  }

  //先聲明一個(gè)對(duì)象字面量

  var Animal = {

      somthing: 'apple',

      eat: function() {

        console.log("eat " + this.somthing);

      }

    }

    //不需要定義一個(gè)Person的子類,只要執(zhí)行一次克隆即可

  var Cat = clone(Animal);

  //可以直接獲得Person提供的默認(rèn)值,也可以添加或者修改屬性和方法

  console.log(Cat.eat());

  Cat.somthing = 'orange';

  console.log(Cat.eat());

  //聲明子類,執(zhí)行一次克隆即可

  var Someone = clone(Cat);

  </script>

</body>

</html>

我們可以試驗(yàn)一下,JS類的繼承 children.constructor==father 返回的是true,而原型繼承children.constructor==father 返回的是false;

以上這篇淺析JS原型繼承與類的繼承就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:淺析JS原型繼承與類的繼承
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)