您好,登錄后才能下訂單哦!
這篇文章給大家介紹使用JavaScript怎么實現一個封裝功能,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
1.在 Object類上增加一個擴展方法
//聲明一個父類 function Person(name){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } //聲明一個子類 function Student(){ this.no=no; this.study=function(){ alert("我在學習!"); } } // 通過循壞,將父類對象的所有屬性和方法,全部賦給子類對象 Object.prototype.extend=function(parent){ for(var i in parent){ this[i].parent[i]; } } var p=new Person("張三",12); var s=new Student("1234567"); //子類對象調用這個擴展方法 s.extend() console.log(s);
上述實現繼承的原理:
通過循壞,將父類對象的所有屬性和方法,全部賦給子類對象。關鍵點在于for-in循壞,即使不擴展Object,也能通過簡單的循壞實現操作。
但是用這種方法實現繼承也有一些缺點:
①無法通過一次實例化,直接拿到完整的子類對象。而需要先拿到父類對象和子類對象兩個對象,再手動合并;
②擴展Object的繼承方法,也會保留在子類的對象上。
再來看看第二種實現繼承的方法吧~
2.使用原型繼承
在介紹這種方法之前先來說兩個概念:原型對象與原型
1、prototype:函數的原型對象
①只有函數才有prototype,而且所有函數必有prototype
②prototype本身也是一個對象!
③prototype指向了當前函數所在的引用地址!
2、__proto__:對象的原型!
①只有對象才有__proto__,而且所有對象必有__proto__
②__proto__也是一個對象,所以也有自己的__proto__,順著這條線向上照的順序,就是原型鏈。
③函數、數組都是對象,都有自己的__proto__
//聲明父類 function Person(name,age){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } //聲明子類 function Student(no){ this.no=no; this.study=function(){ alert("我在學習!我叫"+this.name+"今年"+this.age"); } } //將父類對象賦給子類的prototype Student.prototype=new Person("張三",14); //拿到子類對象時,就會將父類對象的所有屬性和方法,添加到__proto__ var s=new Student(); s.study();
使用原型繼承的原理:
將父類對象,賦值給子類的prototype,那么父類對象的屬性和方法就會出現在子類的prototype中。那么,實例化子類時,子類的prototype又會到子類對象的__proto__中,最終,父類對象的屬性和方法,會出現在子類對象的__proto__中。
這種繼承的特點:
①子類自身的所有屬性都是成員屬性,父類繼承過來的屬性都是原型屬性。
②依然無法通過一步實例化拿到完成的子類對象。
第三種實現繼承的方法:
call()和apply()還有bind(),這三種方法很相似,只有在傳參方面有所不同。
function Person(name,age){ this.name=name; this.age=age; this.say=function(){ alert("我叫"+this.name); } } function Student(no,name,age){ this.no=no; this.study=function(){ alert("我在學習!"); } //將父類函數的this,指向為子類函數的this Person.call(this,name,age); } var s=new Student(12,"張三",24); console.log(s);
三個函數的唯一區別,在于接受func的參數列表的方式不同,除此之外,功能上沒有任何差異!
三個函數的寫法(區別):
call寫法:func.call(func的this指向的obj,func參數1,func參數2,...);
apply寫法:func.apply(func的this指向的obj,[func參數1,func參數2,...]);
bind寫法:func.bind(func的this指向的obj)(func參數1,func參數2,...);
關于使用JavaScript怎么實現一個封裝功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。