91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript繼承實現的方式有哪些

發布時間:2023-04-03 11:24:59 來源:億速云 閱讀:97 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“javascript繼承實現的方式有哪些”,內容詳細,步驟清晰,細節處理妥當,希望這篇“javascript繼承實現的方式有哪些”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

什么是繼承

用官方點的話講繼承是面向對象三大特征之一,可以使得子類具有父類的屬性和方法,同時還可以在子類中重新定義以及追加屬性和方法。通俗的來說繼承就是子類可以從父類那里復用一些屬性和方法,從而達到復用代碼的一個效果。

實現繼承的6種方式

  • 原型鏈繼承

  • 構造函數繼承

  • 組合繼承(偽經典繼承)

  • 原型式繼承

  • 寄生式繼承

  • 寄生組合式繼承

  • class 類繼承

1. 原型鏈繼承

function Person() {
    this.name = 'bruce'
    this.age = 18
    this.gender = '男'
    this.like = {
        sport: 'running',
        book: 'JavaScript'
    }
    this.getName = function() {
        console.log(this.name);
    }
}

function Student() {
    this.school = '新華小學'
}

let s = new Student()
console.log(s.name);   // 未繼承前 undefined

Student.prototype = new Person()  // 繼承之后
let s1 = new Student()
s1.getName()  // bruce
console.log(s1.like.book);  // JavaScript
s1.like.book = 'Java'   // 修改引用類型的值
s1.name = 'jack'  // 修改非引用類型的值
console.log(s1.like.book);  // Java
s1.getName()  // jack
console.log('----------');
let s2 = new Student()
s2.getName()  // bruce
console.log(s2.like.book);  // Java

所謂的原型鏈繼承,在我的理解就是子類通過原型鏈來繼承到父類的屬性,在上面的代碼中我們也可以看到在子類實例s沒有繼承到父類的屬性時,子類去訪問父類才有的屬性值為:undefined

在將父類實例對象掛載到子類Student構造函數的原型上面后,那么此時子類的原型上面就有了父類的全部屬性。因為Person的實例對象被顯示的掛載到了Student的原型上面。所以子類在繼承之后,所有實例化的子類都擁有了跟父類一樣的屬性,于是這樣子類就通過原型鏈實現了繼承。

優點: 子類可以繼承到父類的方法。

缺點:

  • 會在子類實例上共享父類所有的引用類型數據,也就是子類的原型被父類屬性覆蓋。

  • 子類實例不能給父類構造函數傳參。

function Person(t) {
    this.property = t
}

function Student(t) {
    this.typeproperty = t
}
Student.prototype = new Person()
let s=new Student('a')
console.log(s.property)  // undefined
console.log(s.typeproperty)  // a

這樣子類實例傳的參數就不能給到父類構造函數里面了。

2. 構造函數繼承

function Person(name,age) {
    this.name = name
    this.age = age
    this.like = {
        sport: 'running',
        book: 'JavaScript'
    }
    this.getName = function () {
        console.log(this.name);
    }
}
Person.prototype.sayHello = function () {
    console.log('你好');
}

function Student(name, age,) {
    Person.call(this, name, age)  // 借用構造函數
}

let s1 = new Student('bruce',18)
s1.getName()   // bruce
s1.name='jack'
s1.getName()  // jack
s1.like.sport='swimming'
console.log(s1.like.sport);  // swimming
console.log('------');
let s2=new Student('lucy',19)
s2.getName()  // lucy
console.log(s2.like.sport);  // running

構造函數繼承就是使用強制改變 this 指向,借用一個構造函數繼承。相較于原型鏈繼承,構造函數繼承不會共享父類上的引用類型數據,不會互相影響。

缺點:1.不能訪問到父類原型屬性上面的方法和參數,即 Person.prototype 上的都不能訪問到。

Person.prototype.sayHello = function () {  // 在 Person 的原型上面加一個方法
    console.log('你好');
}

let s1 = new Student('bruce',18)
s1.sayHello()  // s1.sayHello is not a function

3. 組合繼承(偽經典繼承)

相較于原型鏈繼承,構造函數繼承好像已經非常完美了,但是它還是存在著一個最大的缺點就是:不能繼承到父類的原型上面的屬性。但是原型鏈繼承就好像沒有這個問題,如果將這兩個繼承方式組合起來搭配使用是不是就能解決掉所有問題,于是這就有了組合繼承。

function Person(name, age) {
    this.name = name
    this.age = age
    this.like = {
        sport: 'running',
        book: 'JavaScript'
    }
    this.getName = function () {
        console.log(this.name);
    }
}
Person.prototype.sayHello = function () {
    console.log('你好');
}

function Student(name, age) {
    Person.call(this, name, age)  // 構造函數繼承
}
Student.prototype = new Person()  // 原型鏈繼承

let s1 = new Student('bruce', 18)
s1.sayHello() // 你好
console.log(s1);

上面先在子類內使用構造函數繼承將父類的顯示屬性掛載到子類上面,此時仍然存在著構造函數繼承中子類不能訪問到父類原型上面屬性的缺點。

所以下面配合原型鏈繼承將父類實例掛載到子類的原型上,此時子類就可以訪問父類的原型上的屬性,同時構造函數繼承將子類的原型被父類屬性覆蓋的問題解決。

組合繼承將前面兩種繼承的缺點都補全了,但是它也有缺點:

不足:重復調用兩次父類函數。

javascript繼承實現的方式有哪些

4. 原型式繼承

function object(o){  // 參數為父類  
    function F(){}  
    F.prototype=o  
    return new F()  
}  
  
const person={  
    sex:'man',  
    age:20  
}  
  
let realPerson=object(person)  
console.log(realPerson.sex);// man

通過在一個構造函數的原型上掛載父類,此時再將這個掛載了父類的構造函數實例返回出來,那么這個實例的隱式原型就為這個父類,所以此時子類實例對象可以訪問到父類上的屬性,這就是原型式繼承。這個看起來跟理解起來是不是跟原型鏈繼承很像,也挺好理解的。

缺點: 如果父類屬性有引用類型,那么這個引用類型也會被共享出來。

 function object(o){  
    function F(){}  
    F.prototype=o  
    return new F()  
}  
  
const person={  
    sex:'man',  
    age:20,  
    like:{  
        sports:'running'  
    }  
}  
  
let r1=object(person)  
console.log(r1.like);// { sports: 'running' }  
let r2=object(person)  
r2.like.sports='singing'  
console.log(r1.like); // { sports: 'singing' }

實例化兩個不同的對象,更改 r2 的sports 屬性,結果 r1 的 sports 屬性也被修改。

5. 寄生式繼承

這種繼承方式跟原型式繼承有著異曲同工之妙,只不過可以增強這個父類。其存在的缺點也與原型式繼承一樣。

 function createPerson(original) {  
    var clone = Object.create(original)  
    clone.say = function() {     // 增強這個對象  
        console.log('hello');  
    }  
    return clone  
}

6.寄生組合式繼承

這個是一個比較完美的繼承方式,使用組合繼承與寄生繼承。

function Person(name, age) {
    this.name = name
    this.age = age
    this.like = {
        sport: 'running',
        book: 'JavaScript'
    }
    this.getName = function () {
        console.log(this.name);
    }
}
Person.prototype.sayHello = function () {
    console.log('你好');
}

function Student(name, age) {
    Person.call(this, name, age)  // 借用構造函數
}
const Fn=function(){}
Fn.prototype=Person.prototype

Student.prototype = new Fn()



let s1 = new Student('bruce', 18)
s1.sayHello() // 你好
console.log(s1);

這種繼承方式結合了組合繼承,借助一個空的構造函數,將父類的原型掛載到這個空的構造函數上面,然后將其附在子類的原型上面,這樣就解決了組合式繼承的缺點。

javascript繼承實現的方式有哪些

7.class 類繼承

Class 可以通過extends關鍵字實現繼承,讓子類繼承父類的屬性和方法。

class Person{
    constructor(name){
        this.name=name
    }
}

class Student extends Person{
    constructor(name,age){
        super(name)
        this.age=age
    }
}

let s=new Student('bruce',20)
console.log(s);  //Student { name: 'bruce', age: 20 }

讀到這里,這篇“javascript繼承實現的方式有哪些”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蓝田县| 绥棱县| 北辰区| 上蔡县| 钟山县| 西华县| 基隆市| 泾阳县| 高邮市| 白河县| 吉首市| 安多县| 寻乌县| 广东省| 绵竹市| 温泉县| 鄂托克前旗| 鄂尔多斯市| 黄山市| 昆明市| 南投县| 麻江县| 黑水县| 正安县| 钟山县| 陇南市| 木里| 台湾省| 清苑县| 平定县| 柯坪县| 宾阳县| 青岛市| 清远市| 宁河县| 马龙县| 泗洪县| 康乐县| 青州市| 凤庆县| 徐水县|