首页 > 开发 > JS > 正文

不错的一篇关于javascript-prototype继承

2024-09-06 12:41:31
字体:
来源:转载
供稿:网友
1.最基本的用法 把ClassA的一个实例赋值给ClassB,
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继承有执行效率高,不会浪费内存,为父类动态添置方法后子类中马上可见等的优点。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表