成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JS篇 - js的繼承

kun_jian / 1730人閱讀

摘要:定義漢語(yǔ)解釋泛指把前人的作風(fēng)文化知識(shí)等接受過(guò)來(lái)計(jì)算機(jī)術(shù)語(yǔ)解釋繼承可以使得子類具有父類的屬性和方法或者重新定義追加屬性和方法等先來(lái)個(gè)父類祭天原型鏈繼承該實(shí)例對(duì)象有一個(gè)為,原型上有一個(gè)是先找當(dāng)前屬性,再找原型父子之間存在關(guān)系,但子類并不會(huì)創(chuàng)建新

定義

漢語(yǔ)解釋:泛指把前人的作風(fēng)、文化、知識(shí)等接受過(guò)來(lái)
計(jì)算機(jī)術(shù)語(yǔ)解釋:繼承可以使得子類具有父類的屬性和方法或者重新定義、追加屬性和方法等

先來(lái)個(gè)父類祭天
  function Animal(name) {
    this.name = name || "animal";
    this.speak = function () {
      console.log("speak");
    }
  }
  Animal.prototype.move = function () {
    console.log("move");
  }
原型鏈繼承
  function Cat() {
    this.getName = function () {
      console.log(this.name);
    };
  }

  Cat.prototype = new Animal("cat1");
  var cat = new Cat();
  cat.name = "cat2";
  console.log(cat);//該實(shí)例對(duì)象有一個(gè)name為cat2,原型上有一個(gè)name是cat1
  cat.getName();//cat2(先找當(dāng)前屬性,再找原型)
  console.log(cat instanceof Cat);//true
  console.log(cat instanceof Animal);//true
父子之間存在關(guān)系,但子類并不會(huì)創(chuàng)建新的屬性,set子類屬性并不會(huì)覆蓋原型上的屬性,get屬性只不過(guò)是根據(jù)先讀取當(dāng)前屬性再讀取原型的優(yōu)先級(jí)
構(gòu)造函數(shù)繼承
  function Dog(name) {
    Animal.call(this);
    this.name = name || "doggy";
  }

  var dog = new Dog();
  console.log(dog);//只有子類屬性
  console.log(dog instanceof Dog); // true
  console.log(dog instanceof Animal); // false
實(shí)際上只是利用父類構(gòu)造函數(shù)來(lái)添加子類屬性,父子之間沒(méi)有什么關(guān)系
ES6繼承(完美繼承)
  class Animal2 {
    constructor(name) {
      this.name = name || "animal2";
      this.speak = function () {
        console.log("speak");
      }
    }
  }

  Animal2.prototype.move = function () {
    console.log("move");
  }
  var animal2 = new Animal2("god2");
  console.log(animal2);

  class Bird extends Animal2 {
    getName() {
      console.log(this.name);
    }
  }

  var bird = new Bird("bird");
  console.log(bird);//既有父類的屬性,原型鏈也指向父類
  bird.getName();
  console.log(bird instanceof Bird); // true
  console.log(bird instanceof Animal2); // true

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/109558.html

相關(guān)文章

  • 體驗(yàn)js之美第八課-面向?qū)ο髣?chuàng)建和繼承終結(jié)

    摘要:概述到這里我們講說(shuō)面向?qū)ο蟮南盗胁糠值淖詈笠粋€(gè)課程,面向?qū)ο蟊仨氄莆諆蓚€(gè)東西一個(gè)是對(duì)象的創(chuàng)建一個(gè)是繼承。只需要記住一句話,屬性放在構(gòu)造函數(shù)里面,方法放在原型上。 概述 到這里我們講說(shuō)js面向?qū)ο蟮南盗胁糠值淖詈笠粋€(gè)課程,面向?qū)ο蟊仨氄莆諆蓚€(gè)東西一個(gè)是對(duì)象的創(chuàng)建一個(gè)是繼承。這節(jié)課我們重點(diǎn)說(shuō)說(shuō)這兩個(gè)問(wèn)題最后我們說(shuō)下在ES6里面面向?qū)ο笤趺赐妗?1對(duì)象的創(chuàng)建 我們第一節(jié)課已經(jīng)就會(huì)用了,單體模...

    jzzlee 評(píng)論0 收藏0
  • javascript基礎(chǔ):關(guān)于js面向?qū)ο?em>的理解

    摘要:關(guān)于中面向?qū)ο蟮睦斫饷嫦驅(qū)ο缶幊趟且环N編程思想我們的編程或者學(xué)習(xí)其實(shí)是按照類實(shí)例來(lái)完成的學(xué)習(xí)類的繼承封裝多態(tài)封裝把實(shí)現(xiàn)一個(gè)功能的代碼封裝到一個(gè)函數(shù)中一個(gè)類中以后再想實(shí)現(xiàn)這個(gè)功能,只需要執(zhí)行這個(gè)函數(shù)方法即可,不需要再重復(fù)的編寫(xiě)代碼。 關(guān)于js中面向?qū)ο蟮睦斫?面向?qū)ο缶幊?oop) 它是一種編程思想 (object-oriented programming ), 我們的編程或者學(xué)習(xí)其...

    roadtogeek 評(píng)論0 收藏0
  • javascript基礎(chǔ):關(guān)于js面向?qū)ο?em>的理解

    摘要:關(guān)于中面向?qū)ο蟮睦斫饷嫦驅(qū)ο缶幊趟且环N編程思想我們的編程或者學(xué)習(xí)其實(shí)是按照類實(shí)例來(lái)完成的學(xué)習(xí)類的繼承封裝多態(tài)封裝把實(shí)現(xiàn)一個(gè)功能的代碼封裝到一個(gè)函數(shù)中一個(gè)類中以后再想實(shí)現(xiàn)這個(gè)功能,只需要執(zhí)行這個(gè)函數(shù)方法即可,不需要再重復(fù)的編寫(xiě)代碼。 關(guān)于js中面向?qū)ο蟮睦斫?面向?qū)ο缶幊?oop) 它是一種編程思想 (object-oriented programming ), 我們的編程或者學(xué)習(xí)其...

    newtrek 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<