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

溫馨提示×

溫馨提示×

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

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

JS構造函數實例對象和原型對象之間的關系是什么

發布時間:2021-10-29 17:34:36 來源:億速云 閱讀:159 作者:iii 欄目:web開發

本篇內容介紹了“JS構造函數實例對象和原型對象之間的關系是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

    //自定義構造函數   
     function Person(name,age,gender) 
     {          
         this.name = name;          
         this.age = age;          
         this.gender = gender;          
         this.eat = function () 
         {            
             console.log("吃大蒜拌臭豆腐加榴蓮醬");          
         };     
     }

       構造函數---->創建對象per

       var per = new Person('Linda',23,‘female’);

       

       補充:console.dir(per)可以打印出對象per的結構(屬性與屬性值)       

JS構造函數實例對象和原型對象之間的關系是什么

   以上我們可以得出實例對象與構造函數之間的關系如下:

1. 實例對象是通過構造函數來創建的---創建的過程叫實例化

 2. 如何判斷對象是不是某構造器實例化的結果?(推薦第二種

     1) 通過構造器的方式, 即實例對象.構造器==構造函數名字: console.log(dog.constructor==Animal);

     2) 實例對象 instanceof 構造函數名字: console.log(dog instanceof Animal);


構造函數創建對象會帶來問題,我們來看以下例子

       function Person(name, age) {
          this.name = name;
          this.age = age;
          this.eat = function () {
            console.log("今天吃紅燒土豆");
          }
        }
        var per1 = new Person("小白", 20);
        var per2 = new Person("小黑", 30);
            per1.eat();
            per2.eat();

   JS構造函數實例對象和原型對象之間的關系是什么

    通過打印結果為false可以得出結論per1,per2并不共享eat方法,那么這很容易推論出通過自定義構造函數創建的對象實例并不節約內存空間,以此引出了原型來解決這個問題。

            function Person(name,age) {
                  this.name=name;
                  this.age=age;
             }
             
             //通過原型來添加方法,解決數據共享,節省內存空間
             Person.prototype.eat=function () {
                 console.log("吃涼菜");
             };
                
             var p1=new Person("小明",20);
             var p2=new Person("小紅",30);

JS構造函數實例對象和原型對象之間的關系是什么

通過打印結果我們發現p1,p2兩個實例對象共享eat方法,實現了數據共享,節省內存空間。但是我們查看實例對象的結構并沒有發現eat方法 ,但是對象確實能調用到eat方法,這是什么原因呢?

     接著我們再來查看一下構造函數Person的結構

JS構造函數實例對象和原型對象之間的關系是什么

       通過console.dir(p1)查看對象的結構時,我們發現它除了age,name屬性外,還存在一個_proto_屬性,值是一個對象,在JavaScript中被稱為隱式原型。一個對象的隱式原型指向構造該對象的構造函數的原型prototype, 這也保證了實例能夠訪問在構造函數原型中定義的屬性和方法。

“JS構造函數實例對象和原型對象之間的關系是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

js
AI

大庆市| 容城县| 克拉玛依市| 弥渡县| 西乡县| 肇庆市| 偃师市| 尉氏县| 永清县| 云安县| 海城市| 右玉县| 平陆县| 兰考县| 平凉市| 汾阳市| 平潭县| 南昌市| 常德市| 天等县| 扶绥县| 崇左市| 合水县| 内江市| 始兴县| 平江县| 勃利县| 高平市| 延长县| 花垣县| 进贤县| 游戏| 武定县| 华亭县| 泰州市| 林口县| 黄大仙区| 丰都县| 镶黄旗| 金秀| 云霄县|