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

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

我們先看JS類的繼承

<!DOCTYPE html>

<html>

<head>

  <meta charset="UTF-8">

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

</head>

<body>

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

  <script type="text/javascript">

  //先聲明一個超類

  var Animal = function(name) {

      this.name = name;

    }

    //給這個超類的原型對象上添加方法

  Animal.prototype.Eat = function() {

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

  };

  //實例化這個超

  var a = new Animal("Animal");

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

  var Cat = function(name, sex) {

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

      Animal.call(this, name);

      this.sex = sex;

    }

    //這個子類的原型對象等于超類的實例

  Cat.prototype = new Animal();

  //因為子類的原型對象等于超類的實例,所以prototype.constructor這個方法也等于超類構(gòu)造函數(shù)

  console.log(Cat.prototype.constructor);

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

  Cat.prototype.constructor = Cat;

  console.log(Cat.prototype.constructor);

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

  Cat.prototype.getSex = function() {

      return this.sex;

    }

    //實例化這個子類

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

  //自身的方法

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

  //繼承超類的方法

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

  </script>

</body>

</html>

我們再看JS原型繼承

<!DOCTYPE html>

<html>

<head>

  <meta charset="UTF-8">

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

</head>

<body>

  <!--原型繼承-->

  <script type="text/javascript">

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

  var clone = function(obj) {

    var _f = function() {};

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

    _f.prototype = obj;

    return new _f;

  }

  //先聲明一個對象字面量

  var Animal = {

      somthing: 'apple',

      eat: function() {

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

      }

    }

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

  var Cat = clone(Animal);

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

  console.log(Cat.eat());

  Cat.somthing = 'orange';

  console.log(Cat.eat());

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

  var Someone = clone(Cat);

  </script>

</body>

</html>

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

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

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機網(wǎng)站地址:淺析JS原型繼承與類的繼承

2025國考·省考課程試聽報名

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