JS原型和继承
//所有的函数都有一个prototype属性
function aa() {
}
console.info(aa.prototype);
//这个prototype属性引用了一个对象,即原型,初始化时是一个空对象,也就是没有一个成员(即原型属性和原型方法)。
var i = 0;
for (j in aa.prototype) {
console.info(j);
i++;
}
alert("member: " + i);//alert出原型所有属性和方法个数。 0个属性和方法 function AA() { }
AA.prototype.name = 'leyi';
AA.prototype.fn = function () {
return 'hello world!'
};
var bb = new AA();
//实例化对象没有原型对象,他可以通过__proto__来取得原型链上的原型属性和原型方法
console.info(bb.prototype)//undefined
console.info(bb.__proto__) //指向AA.prototype
//那么获取bb的属性和方法就可以通过原型链获取AA原型上的方法属性
console.info(bb.name === bb.__proto__.name);//leyi
console.info(bb.fn() === bb.__proto__.fn());//hello world!
//bb的的构造器函数就是AA.prototype.constructor
console.info(bb.constructor === AA.prototype.constructor)//true
//bb的的构造器函数的原型就是AA.prototype
console.info(bb.constructor.prototype === AA.prototype)//true //继承 //一、通过对象冒充实现继承
function X(width, height) {
this.width = width;
this.height = height;
} function Y(w, h) {
this.fn = X;//让父类的构造函数成为子类的方法
this.fn(w, h);//执行该方法,继承了X方法的width,height属性
delete this.fn; //删掉该方法
this.draw = function () {
console.info(this.width + '---' + this.height);//打印继承来的两个属性
}
}
new Y(100, 200).draw();//100---200 //二、通过call apply实现继承,原理跟上面差不多
function XX(width, height) {
this.width = width;
this.height = height;
} function YY(w, h) {
XX.call(this, w, h);//or XX.apply(this,[w,h]);
this.draw = function () {
console.info(this.width + '---' + this.height);//打印继承来的两个属性
}
}
new YY(300, 400).draw();//300---400 //三、通过原型链实现继承
function XXX(width, height) {
this.fn = function () {
console.info('haha')
}
} function YYY() {
this.draw = function () {
this.fn();
}
}
YYY.prototype = new XXX();
var yyy = new YYY()
console.info(yyy.constructor)//这里有点小问题,yyy构造器函数指向了XXX
//YYY.prototype是YYY的原型,yyy.constructor.prototype是XXX的原型
console.info(yyy.constructor.prototype === YYY.prototype)//false
//修正指向
YYY.prototype.constructor = YYY//将YYY原型的构造器设置指向为YYY构造函数
console.info(yyy.constructor.prototype === YYY.prototype)//true
console.info(yyy.constructor)//YYY
yyy.draw(); //混合式继承
function XXXX(width, height) {
this.width = width;
this.height = height;
}
XXXX.prototype.halo = 'halo!' function YYYY(w, h) {
XXXX.call(this, w, h);//通过call继承XXXX的字段属性,并将其初始化
this.draw = function () {
console.info(this.width + '---' + this.height);
}
}
YYYY.prototype = new XXXX();
YYYY.prototype.constructor = YYYY;
new YYYY(666, 666).draw();//666---666
console.info(new YYYY().halo)//halo! var cst = new YYYY()
console.info(cst.constructor.prototype === YYYY.prototype)//true
console.info(cst.constructor)//YYYY
参考:
http://www.cnblogs.com/ljchow/archive/2010/06/08/1753526.html
http://javapolo.iteye.com/blog/1996871
JS原型和继承的更多相关文章
- js原型链+继承 浅析
名称: prototype--原型对象 __proto__--属性 原型链与继承网上搜索定义,看起来挺绕的 .先说继承: 所有的对象实例都可以共享原型对象包含的属性和方法 例如一个实例A ...
- [js]js原型链继承小结
这是之前总结的, 发现有很多的毛病,就是重点不突出,重新翻看的时候还是得耗费很长时间去理解这玩意. js中的继承 js中什么是类 1,类是函数数据类型 2.每个类有一个自带prototype属性 pr ...
- 彻底弄懂JS原型与继承
本文由浅到深,循序渐进的将原型与继承的抽象概念形象化,且每个知识点都搭配相应的例子,尽可能的将其通俗化,而且本文最大的优点就是:长(为了更详细嘛). 一.原型 首先,我们先说说原型,但说到原型就得从函 ...
- js原型链继承的傻瓜式详解
本文争取用最简单的语言来讲解原型链继承的OOP原理 0.如果对原型继承还没有大致了解,完全一头雾水,请先阅读 <JavaScript高级程序设计>第六章最后部分的寄生组合式继承 或者_廖雪 ...
- js原型与继承
demofunction Fun(){} var foo = new Fun();foo.__proto__ === Fun.prototype 摘要 1.js本身不提供类实现,es6引入了class ...
- 【JS】深入理解JS原型和继承
前言 在学习JS中的原型,原型链,继承这些知识之前,我们先学习下基础知识:函数和对象的关系. 我们一直都知道,函数也是对象的一种,因为通过instanceof就可以判断出来.但是函数和对象的关系并不 ...
- JS原型链继承
继承普通版 继承逻辑上都差不多,普通版调用方式比较繁琐,不利于反复大量的使用: (function (){ //创建一个人员类 function Person(name){ this.name = n ...
- js原型链继承及调用父类方法
方法1: var Parent= function () { }; Parent.prototype.process = function(){ alert('parent method'); }; ...
- 一个小实例理解js 原型和继承
导语1:一个构造函数的原型对象,其实就是这个构造函数的一个属性而已,属性名叫prototype,值是一个对象,对象中有一些属性和方法,所以每个构造函数的实例对象都拥有这些属性和方法的使用权. 导语2: ...
随机推荐
- WPF中的image控件的Source赋值
WPF中的Image控件Source的设置 1.XAML中 简单的方式(Source="haha.png"); image控件的Source设置为相对路径后(Source=&quo ...
- [zz]谱聚类
了凡春秋USTC 谱聚类 http://chunqiu.blog.ustc.edu.cn/?p=505 最近忙着写文章,好久不写博客了.最近看到一个聚类方法--谱聚类,号称现代聚类方法,看到它简洁的公 ...
- 【FTP】FTP文件上传下载-支持断点续传
Jar包:apache的commons-net包: 支持断点续传 支持进度监控(有时出不来,搞不清原因) 相关知识点 编码格式: UTF-8等; 文件类型: 包括[BINARY_FILE_TYPE(常 ...
- USVN
我们最近将快盘上的东西迁移到了svn上,因为快盘总是不会不小心删掉或者修改了某些文件.为了能保留历史记录我们统一迁移到svn上.为了方便权限管理,我对比了几个svn的权限管理工具,最后觉得还是usvn ...
- Zedboard安装桌面系统ubuntu及opencv(2)
接上一篇,下面安装opencv. 一般都是参照陆佳华那本白色封皮的<软硬件协同设计>,但是不得不说这本书实在太粗糙了,很多的细节都没有说明. 首先,在PC和这块板子的方法是一样的,所以PC ...
- Join two DataTables in C#
var query = (from x in a.AsEnumerable() join y in b.AsEnumerable() on x.Field<int>("col1& ...
- git学习3:远程仓库
Git是分布式版本控制系统,同一个git仓库,可以分布到不同的机器上,那么需要有一台机器上有一个原始版本库,这样别的机器可以克隆这个原始版本库,那么这台机器就是github. 1,创建SSH Key. ...
- caffe.exe (caffe.bin)用法回顾
caffe.bin :command line brew usage : caffe <command><args> commands: train: 训练或者微调一个网络 ...
- CentOS7:安装Puppet
环境说明: 192.168.154.137 master.localdomain #Puppet Server 192.168.154.138 agent1.localdomain #Puppet A ...
- 01-C#入门(分支控制语句)
说实话,<C#入门经典>这本书对入门的同学来说真的太棒了,先不说内容如何,就作者先以控制台(命令行)调试程序的方法,就能够最大限度地让你关注学习的内容,而不是花哨的界面调试. 现在学习是下 ...