javascript中的類,繼承,構(gòu)造函數(shù)詳解
前言
在es5中實(shí)現(xiàn)一個(gè)構(gòu)造函數(shù),并用new調(diào)用,即可得到一個(gè)類的實(shí)例。到了es6發(fā)布了Class的寫法,js的面向?qū)ο笞兂梢沧兊帽容^規(guī)范了。聊到類就不能不說類的構(gòu)造函數(shù)以及類如何繼承
一、Class類
定義一個(gè)類:
class A {
constructor(name){
this.name = name
}
getName(){
return this.name
}
}
var newA = new A("A")
console.log(newA.getName()) // A
二、es5構(gòu)造函數(shù)
在es5中沒有Class的寫法,想要實(shí)現(xiàn)一個(gè)類的寫法是這樣的:
class A {
constructor(name){
this.name = name
}
getName(){
return this.name
}
}
var newA = new A("A")
console.log(newA.getName()) // A
三、實(shí)例、類的關(guān)系
實(shí)例的原型指向類的原型
console.log(newA.__proto__ === A.prototype) // true
關(guān)于這個(gè)可以了解一下實(shí)例化的過程究竟發(fā)生了什么,查看MDN的連接:new操作符
- 創(chuàng)建一個(gè)空的簡(jiǎn)單JavaScript對(duì)象(即{});
- 為步驟1新創(chuàng)建的對(duì)象添加屬性__proto__,將該屬性鏈接至構(gòu)造函數(shù)的原型對(duì)象 ;
- 將步驟1新創(chuàng)建的對(duì)象作為this的上下文 ;
- 如果該函數(shù)沒有返回對(duì)象,則返回this。
Constructor
console.log(A.prototype.constructor) // Class A
所有的對(duì)象都會(huì)從原型上繼承一個(gè)constructor屬性,是對(duì)函數(shù)本身的引用,也就是說指向函數(shù)本身。
這里實(shí)例newA的原型與A的原型相等,兩者的原型的constuctor又都指向A本身。
需要注意的是constrctor是可以被修改的:參照MDN官方實(shí)例:constructor
function Type() { };
var types = [
new Array,
[],
new Boolean,
true, // remains unchanged
new Date,
new Error,
new Function,
function(){},
Math,
new Number,
1, // remains unchanged
new Object,
{},
new RegExp,
/(?:)/,
new String,
"test" // remains unchanged
];
for(var i = 0; i < types.length; i++) {
types[i].constructor = Type;
types[i] = [ types[i].constructor, types[i] instanceof Type, types[i].toString() ];
};
console.log( types.join("\n") );
只有,true、1、“test”這種只讀的原生結(jié)構(gòu)不可被修改constuctor
四、繼承
es6繼承
class Father{
constructor(name){
this.name = name
}
}
class Son extends Father{
constructor(name,sname){
super(name)
this.sname = sname
}
getSon(){
return this
}
}
var newSon = new Son("f","s")
console.log(newSon.getSon()) // Son {name: 'f', sname: 's'}
es5繼承的實(shí)現(xiàn)
// 寄生組合繼承
function Sub(name){
// 優(yōu)先執(zhí)行this綁定,以免覆蓋子類的構(gòu)造的值
// 這里還有一個(gè)作用是拷貝了父類屬性,避免所有子類共享引用屬性?。。。?
Person.call(this)
this.name = name || 's'
}
// 復(fù)制一份父類的原型,避免修改原型影響其他實(shí)例
var fn = function(){}
fn.prototype = Person.prototype
Sub.prototype = new fn()
var sub = new Sub('sub')
sub.showName()
// user extend.html:19
// my name is sub extend.html:21
關(guān)于繼承詳細(xì)的可以參考這篇:前端必知必會(huì)ES5、ES6的7種繼承
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
基于JavaScript實(shí)現(xiàn)瀑布流布局(二)
這篇文章主要介紹了原生JavaScript實(shí)現(xiàn)瀑布流布局的相關(guān)資料,實(shí)現(xiàn)鼠標(biāo)下拉圖片自動(dòng)加載效果,和百度圖片效果類似,需要的朋友可以參考下2016-01-01
JavaScript事件概念詳解(區(qū)分靜態(tài)注冊(cè)和動(dòng)態(tài)注冊(cè))
這篇文章主要介紹了JavaScript事件(區(qū)分靜態(tài)注冊(cè)和動(dòng)態(tài)注冊(cè))的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下2021-02-02
打字效果動(dòng)畫的4種實(shí)現(xiàn)方法(超簡(jiǎn)單)
下面小編就為大家?guī)硪黄蜃中Ч麆?dòng)畫的4種實(shí)現(xiàn)方法(超簡(jiǎn)單)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
基于Unit PNG Fix.js有時(shí)候在ie6下不正常的解決辦法
本篇文章是對(duì)Unit PNG Fix.js有時(shí)候在ie6下不正常的解決辦法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
微信小程序開發(fā)(二):頁(yè)面跳轉(zhuǎn)并傳參操作示例
這篇文章主要介紹了微信小程序開發(fā)頁(yè)面跳轉(zhuǎn)并傳參操作,結(jié)合實(shí)例形式詳細(xì)分析了微信小程序頁(yè)面跳轉(zhuǎn)并傳參相關(guān)操作技巧,需要的朋友可以參考下2020-06-06
JS 對(duì)java返回的json格式的數(shù)據(jù)處理方法
下面小編就為大家?guī)硪黄狫S 對(duì)java返回的json格式的數(shù)據(jù)處理方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-12-12
淺談?lì)愃朴?function(){}).call()的js語句
這篇文章主要介紹了淺談?lì)愃朴?function(){}).call()的js語句,的相關(guān)資料,需要的朋友可以參考下2015-03-03

