JavaScript不使用prototype和new实现继承机制
更新时间:2014年12月29日 11:07:58 投稿:hebedich
这篇文章主要介绍了JavaScript不使用prototype和new实现继承机制的相关资料,需要的朋友可以参考下
此方法并非笔者原创,笔者只是在前辈的基础上,加以总结,得出一种简洁实用的JavaScript继承方法。
传统的JavaScript继承基于prototype原型链,并且需要使用大量的new操作,代码不够简洁,可读性也不是很强,貌似还容易受到原型链污染。
笔者总结的继承方式,简洁明了,虽然不是最好的方式,但希望能给读者带来启发。
好了,废话不多说,直接看代码,注释详尽,一看就懂~~~
复制代码 代码如下:
/**
* Created by 杨元 on 14-11-11.
* 不使用prototype实现继承
*
*/
/**
* Javascript对象复制,仅复制一层,且仅复制function属性,不通用!
* @param obj 要复制的对象
* @returns Object
*/
Object.prototype.clone = function(){
var _s = this,
newObj = {};
_s.each(function(key, value){
if(Object.prototype.toString.call(value) === "[object Function]"){
newObj[key] = value;
}
});
return newObj;
};
/**
* 遍历obj所有自身属性
*
* @param callback 回调函数。回调时会包含两个参数: key 属性名,value 属性值
*/
Object.prototype.each = function(callback){
var key = "",
_this = this;
for (key in _this){
if(Object.prototype.hasOwnProperty.call(_this, key)){
callback(key, _this[key]);
}
}
};
/**
* 创建子类
* @param ext obj,包含需要重写或扩展的方法。
* @returns Object
*/
Object.prototype.extend = function(ext){
var child = this.clone();
ext.each(function(key, value){
child[key] = value;
});
return child;
};
/**
* 创建对象(实例)
* @param arguments 可接受任意数量参数,作为构造器参数列表
* @returns Object
*/
Object.prototype.create = function(){
var obj = this.clone();
if(obj.construct){
obj.construct.apply(obj, arguments);
}
return obj;
};
/**
* Useage Example
* 使用此种方式继承,避免了繁琐的prototype和new。
* 但是目前笔者写的这段示例,只能继承父类的function(可以理解为成员方法)。
* 如果想继承更丰富的内容,请完善clone方法。
*
*
*/
/**
* 动物(父类)
* @type {{construct: construct, eat: eat}}
*/
var Animal = {
construct: function(name){
this.name = name;
},
eat: function(){
console.log("My name is "+this.name+". I can eat!");
}
};
/**
* 鸟(子类)
* 鸟类重写了父类eat方法,并扩展出fly方法
* @type {子类|void}
*/
var Bird = Animal.extend({
eat: function(food){
console.log("My name is "+this.name+". I can eat "+food+"!");
},
fly: function(){
console.log("I can fly!");
}
});
/**
* 创建鸟类实例
* @type {Jim}
*/
var birdJim = Bird.create("Jim"),
birdTom = Bird.create("Tom");
birdJim.eat("worm"); //My name is Jim. I can eat worm!
birdJim.fly(); //I can fly!
birdTom.eat("rice"); //My name is Tom. I can eat rice!
birdTom.fly(); //I can fly!
您可能感兴趣的文章:
- Javascript中 关于prototype属性实现继承的原理图
- JavaScript类和继承 prototype属性
- js中继承的几种用法总结(apply,call,prototype)
- 深入了解javascript中的prototype与继承
- javascript prototype的深度探索不是原型继承那么简单
- JavaScript面向对象之Prototypes和继承
- Javascript 原型和继承(Prototypes and Inheritance)
- JavaScript使用prototype原型实现的封装继承多态示例
- javascript基于prototype实现类似OOP继承的方法
- Javascript中的prototype与继承
- JS伪继承prototype实现方法示例
- JavaScript使用prototype属性实现继承操作示例
相关文章
JavaScript 进阶问题列表(各种js代码段108-155)
从基础到进阶,测试你有多了解 JavaScript,刷新你的知识,或者帮助你的 coding 面试! :muscle: :rocket: 我每周都会在这个仓库下更新新的问题2024-11-11
《javascript设计模式》学习笔记三:Javascript面向对象程序设计单例模式原理与实现方法分析
这篇文章主要介绍了Javascript面向对象程序设计单例模式原理与实现方法,结合实例形式分析了《javascript设计模式》中Javascript面向对象单例模式相关概念、原理、用法及操作注意事项,需要的朋友可以参考下2020-04-04
JavaScript模仿Pinterest实现图片预加载功能
图片预加载是web开发中一种应用相当广泛的技术,比如我们在做图片翻转显示等特效的时候,为了让图片在转换的时候不出现等待,我们最好是先让图片下载到本地,然后在继续执行后续的操作。今天本文主要介绍的是利用JS模仿Pinterest图片社交网站的图片预加载功能。2016-10-10
JavaScript判断变量是否为undefined的两种写法区别
这篇文章主要是对JavaScript判断变量是否为undefined的两种写法区别进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助2013-12-12
利用NodeJS和PhantomJS抓取网站页面信息以及网站截图
这篇文章主要介绍了利用NodeJS和PhantomJS抓取网站页面信息以及网站截图的方法,提供实例代码供大家参考2013-11-11


最新评论