JS繼承用法實例分析
本文實例分析了JS繼承的用法。分享給大家供大家參考。具體分析如下:
繼承 : 子類不影響父類,子類可以繼承父類的一些功能 ( 代碼復(fù)用 )
屬性的繼承 : 調(diào)用父類的構(gòu)造函數(shù) call
方法的繼承 : for in : 拷貝繼承 (jquery也是采用拷貝繼承extend)
1. 拷貝繼承
function Person (name){
this.name = name;
}
Person.prototype.showName =function (){
alert(this.name);
}
function Worker(name,job){
Person.call(this,name);
this.job = job;
}
extend(Worker.prototype, Person.prototype);
//如果用Worker.prototype=Person.prototype的話,會造成引用相同的問題
function extend(obj1,obj2){
for(var i in obj2){
obj1[i] = obj2[i]
}
}
var coder = new Worker('magicfly','frontEnd');
coder.showName();
2. 類繼承
function Person (name){
this.name = name;
}
Person.prototype.showName =function (){
alert(this.name);
}
function Worker(name,job){
Person.call(this,name);
this.job = job;
}
//Worker.prototype = new Person();
// 這樣繼承會繼承父級的不必要屬性
function F(){};
F.prototype = Person.prototype;
Worker.prototype = new F();
//通過建立一個臨時構(gòu)造函數(shù)來解決 ,也稱為代理函數(shù)
var coder = new Worker('MAGICFLY','START');
coder.showName();
3. 原型繼承
var a = {
name : '小明'
};
var b = cloneObj(a);
b.name = '小強(qiáng)';
//alert( b.name );
alert( a.name );
function cloneObj(obj){
var F = function(){};
F.prototype = obj;
return new F();
}
適用情況
拷貝繼承: 通用型的 有new或無new的時候都可以
類式繼承: new構(gòu)造函數(shù)
原型繼承: 無new的對象
希望本文所述對大家的javascript程序設(shè)計有所幫助。
相關(guān)文章
Javascript 數(shù)組添加一個 indexOf 方法的實現(xiàn)代碼
Javascript 的字符串有個 indexOf 的方法,能夠返回字符在指定的字符串中的位置,非常有用,本文介紹了如何給 Javascript 數(shù)組也添加一個類似的方法。2009-09-09
javascript中的相等操作符(==與===區(qū)別)
這篇文章主要介紹了javascript中的相等操作符(==與===區(qū)別),需要的朋友可以參考下2019-12-12
jQuery?事件綁定及取消?bind?live?delegate?on?one區(qū)別解析
這篇文章主要介紹了jquery?事件綁定及取消?bind?live?delegate?on?one區(qū)別解析,本文給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-11-11
使用bootstrapValidator插件進(jìn)行動態(tài)添加表單元素并校驗
動態(tài)添加表單元素,并調(diào)用bootstrapValidator的方法為表單添加校驗規(guī)則,調(diào)用addField()方法實現(xiàn)功能。下面通過本文看下具體實現(xiàn)方法吧2016-09-09

