【JS】構造函數、原型對象

構造函數

什麼是構造函數

  構造函數是一種特殊的函數,要用來初始化對象,即爲對象成員變量賦初始值,它總是和new運算符一起使用,我們可以將對象中的一些公共的屬性和方法抽取出來,然後封裝到這個函數裏。
  在構造函數中,其屬性和方法我們成爲成員。並且成員可以天啊及,同時根據添加的方式不同,成員又分爲:實例成員和靜態成員
  靜態成員:在構造函數本身上添加的成員【靜態成員只能通過構造函數來訪問,不能通過實例化對象訪問
                                                              在這裏插入圖片描述
  實例成員:就是構造函數內部通過this添加的成員,uname,age,sing就是實例成員【實例成員只能通過實例化對象來訪問,不可以通過構造函數類訪問
                                                                 在這裏插入圖片描述

構造函數原型:prototype

  其作用就是共享方法。
                                                            在這裏插入圖片描述
【一般我們的公共屬性和定義到構造函數裏面,而公共方法定義在原型對象身上。】
  每一個對象都有一個屬性__proto__指向構造函數的prototype原型對象,之所以我們對象可以使用構造函數prototype原型對象的屬性和方法,是以爲對象有__proto__的存在.

  • __proto__對象原型和原型對象prototype是等價的

  • __proto__對象原型的意義在於對象的查找機制提供了一個方向,或者說一個路線,但它是一個非標準屬性,因此在開發過程中不可以使用這個屬性,他只是內部指向原型對象的prototype
    方法的查找原則:

  • 首先先看本身對象是否有調用的方法,如果有直接執行這個對象上的方法,

  • 如果沒有,因爲有__proto__的存在,就去構造函數原型對象prototype身上去查找這個方法。

constructor構造函數

        對象的原型(__proto__)和構造函數(prototype)原型對象裏面都有一個屬性constructor屬性,constructor我們稱爲構造函數,。

        如果我們修改了原來的原型對象,給原型對象賦值的是一個對象,則必須手動的利用constructor指回原來的構造函數。

              

構造函數、實例和原型對象三者之間的關係

                       

原型鏈

                                             

    1)只要是對象既有__proto__原型,指向原型對象

    2)我們star原型對象裏面的__proto原型指向的事 Object.prototype

                    

 

JS中成員的查找機制(規則)

        1)當訪問一個對象的屬性(包括方法)是,首先查找這個對象自身有沒有該屬性

        2)如果沒有就查找他的原型(也就是__proto__指向的prototype原型對象)

        3)如果還沒有就查找原型對象的原型(Object的原型對象)

        4)以此類推一直找到Object爲止(null)

擴展內置對象

                         

繼承(call())

        在ES6之前通過構造函數+原型對象模擬實現繼承,被稱爲組合繼承

        ----->call()

            作用:調用這個函數,並且修改函數運行時的this的指向

                                     

                      

 

借用構造函數繼承父類型屬性(方法)


                          

 

                                                         

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章