您好,登錄后才能下訂單哦!
這篇文章給大家介紹javascript中有哪些構造函數,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
構造函數注意事項:
1.默認函數首字母大寫
2.構造函數并沒有顯示返回任何東西。new操作符會自動創建給定的類型并返回他們,當調用構造函數時,new會自動創建this對象,且類型就是構造函數類型。
3.也可以在構造函數中顯示調用return.如果返回的值是一個對象,它會代替新創建的對象實例返回。如果返回的值是一個原始類型,它會被忽略,新創建的實例會被返回。
functionPerson(name){
this.name=name;
}
varp1=newPerson('John');
等同于:
functionperson(name){
Objectobj=newObject();
obj.name=name;
returnobj;
}
varp1=person("John");
構造函數怎么辦
1.因為構造函數也是函數,所以可以直接被調用,但是它的返回值為undefine,此時構造函數里面的this對象等于全局this對象。this.name其實就是創建一個全局的變量name。在嚴格模式下,當你補通過new調用Person構造函數會出現錯誤。
2.也可以在構造函數中用Object.defineProperty()方法來幫助我們初始化:
functionPerson(name){
Object.defineProperty(this,"name"{
get:function(){
returnname;
},
set:function(newName){
name=newName;
},
enumerable:true,//可枚舉,默認為false
configurable:true//可配置
});
}
varp1=newPerson('John')
關于javascript中有哪些構造函數就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。