不错的一篇关于javascript-prototype继承
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了不错的一篇关于javascript-prototype继承,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4433字,纯文字阅读大概需要7分钟。
内容图文
![不错的一篇关于javascript-prototype继承](/upload/InfoBanner/zyjiaocheng/375/cf96c5d76fce4935a9749fdfc4586f6e.jpg)
ClassB就继承了ClassA的所有属性。
代码入下:
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
2.从原型继承理论的角度去考虑,
js的原型继承是引用原型,不是复制原型,
所以,修改原型会导致所有B的实例的变化。
代码如下:
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
3.然而 子类对象的写操作只访问子类对象中成员,
它们之间不会互相影响,因此,
写是写子类 读是读原型(如果子类中没有的话)。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
4.每个子类对象都执有同一个原型的引用,
所以子类对象中的原型成员实际是同一个。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
5.构造子类时 原型的构造函数不会被执行
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
6.接下来是致命的,在子类对象中访问原型的成员对象:
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
7.所以 在prototype继承中 原型类中不能有成员对象! 所有成员必须是值类型数据(string也可以)
用prototype继承有执行效率高,不会浪费内存,为父类动态添置方法后子类中马上可见等的优点。
8.prototype继承是通过把子类的原型对象(prototype)设置成父类的一个实例来进行继承的。
9.prototype继承也有四个比较明显的缺点:
缺点一:父类的构造函数不是像JAVA中那样在给子类进行实例化时执行的,而是在设置继承的时候执行的,并且只执行一次。这往往不是我们希望的,特别是父类的构造函数中有一些特殊操作的情况下。
缺点二:由于父类的构造函数不是在子类进行实例化时执行,在父类的构造函数中设置的成员变量到了子类中就成了所有实例对象公有的公共变量。由于JavaScript中继承只发生在“获取”属性的值时,对于属性的值是String,Number和Boolean这些数据本身不能被修改的类型时没有什么影响。但是Array和Object类型就会有问题。
缺点三:如果父类的构造函数需要参数,我们就没有办法了。
缺点四:子类原本的原型对象被替换了,子类本身的constructor属性就没有了。在类的实例取它的constructor属性时,取得的是从父类中继承的constructor属性,从而constructor的值是父类而不是子类。
10.可以针对prototype的缺点进行改造
比如把它写成Function对象的一个方法,这样用的时候方便。
Function.prototype.Extends = function (parentClass)
{
var Bs = new Function();
Bs.prototype = parentClass.prototype;
this.prototype = new Bs();
this.prototype.Super = parentClass;
this.prototype.constructor = this;
}
希望各位 js 高手能把更好的方式介绍给大家
针对第3,6个
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
针对继承,
Array.prototype 就不能继承 ClassA,ClassB
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
带参数的继承问题
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
内容总结
以上是互联网集市为您收集整理的不错的一篇关于javascript-prototype继承全部内容,希望文章能够帮你解决不错的一篇关于javascript-prototype继承所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。