js中使用使用原型(prototype)定義方法的好處詳解
經(jīng)常在前端面試或是和其他同行溝通是,在談到構(gòu)造在JS定義構(gòu)造函數(shù)的方法是最好使用原型的方式:將方法定義到構(gòu)造方法的prototype上,這樣的好處是,通過該構(gòu)造函數(shù)生成的實(shí)例所擁有的方法都是指向一個(gè)函數(shù)的索引,這樣可以節(jié)省內(nèi)存。
當(dāng)然,這種說法沒有任何問題,只是在實(shí)現(xiàn)上,并非只有使用prototype的方式才能達(dá)到這樣的效果,我們可以將方法以函數(shù)的形式定義在構(gòu)造函數(shù)之外,然后在構(gòu)造函數(shù)中通過this.method = method的方式,這樣生成的實(shí)例的方法也都通過索引指向一個(gè)函數(shù),具體如下:
// 不使用原型定義方法:
(function() {
function Constractor() {
this.method1 = method1;
this.method2 = method2;
}
function method1() {
}
function method2() {
}
})();
一般使用原型定義時(shí)代碼如下:
(function () {
function Constractor() {
}
Constactor.prototype = {
method1: function() {
},
method2: function() {
}
};
// 或者
Constactor.prototype.method1 = function() {
};
Constactor.prototype.method2 = function() {
};
})();
理論和實(shí)現(xiàn)都沒有什么高深的,只是為了達(dá)到同樣的目的,可以通過不同的途徑,只是此種方式在使用instanceOf運(yùn)算符來判斷繼承關(guān)系時(shí)就不奏效了。
以上這篇js中使用使用原型(prototype)定義方法的好處詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- javascript prototype的深度探索不是原型繼承那么簡單
- JavaScript為對(duì)象原型prototype添加屬性的兩種方式
- javascript prototype原型詳解(比較基礎(chǔ))
- javascript prototype 原型鏈
- JS構(gòu)造函數(shù)與原型prototype的區(qū)別介紹
- 跟我學(xué)習(xí)javascript的prototype原型和原型鏈
- javascript prototype原型操作筆記
- js使用原型對(duì)象(prototype)需要注意的地方
- 淺談js構(gòu)造函數(shù)的方法與原型prototype
- [js高手之路]圖解javascript的原型(prototype)對(duì)象,原型鏈實(shí)例
- Javascript 原型和繼承(Prototypes and Inheritance)
- JS原型prototype和__proto__用法實(shí)例分析
相關(guān)文章
javascript 獲取函數(shù)形參個(gè)數(shù)
本節(jié)主要介紹了javascript獲取函數(shù)形參個(gè)數(shù)的具體實(shí)現(xiàn),需要的朋友可以參考下2014-07-07
d3.js 地鐵軌道交通項(xiàng)目實(shí)戰(zhàn)
這篇文章主要介紹了d3.js 地鐵軌道交通項(xiàng)目實(shí)戰(zhàn),本文通過實(shí)例代碼項(xiàng)目截圖給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11
BootStrap的select2既可以查詢又可以輸入的實(shí)現(xiàn)代碼
這篇文章主要介紹了bootstrap的select2既可以查詢又可以輸入的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
BootStrap注意事項(xiàng)小結(jié)(五)表單
這篇文章主要介紹了BootStrap注意事項(xiàng)小結(jié)(五)表單的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,,需要的朋友可以參考下2017-03-03
值得分享的輕量級(jí)Bootstrap Table表格插件
這篇文章為大家分享了輕量級(jí)Bootstrap Table表格插件,以表格的形式顯示的數(shù)據(jù),支持單選,復(fù)選框,排序,分頁,顯示/隱藏列等操作,感興趣的小伙伴們可以參考一下2016-05-05
js獲取json中key所對(duì)應(yīng)的value值的簡單方法
下面小編就為大家?guī)硪黄猨s獲取json中key所對(duì)應(yīng)的value值的簡單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03

