首页 > 代码库 > js继承方式(es5)
js继承方式(es5)
1.原型链
- 实现的本质是重写原型对象,代之以一个新类型的实例;
- 给原型添加方法的代码硬顶放在替换原型的语句之后;
- 不能使用对象字面量查收能见原型方法,这样会重写原型链。
- 缺点:包含引用类型值的原型属性会被所有实例共享;在创建子类型时,不能向超类型的构造函数中传递参数。
2.借用构造函数
- 在子类型构造函数的内部调用超类型构造函数;
- 可以在子类型构造函数中想超类型构造函数传递参数;
- 缺点:方法都在构造函数中定义,无法函数复用,且在超类型的原型中定义的方法对子类型不可见的。
3.组合继承
- 使用原型链实现对原型属性和方法的继承,借用构造函数实现对实例属性的继承;
- 缺点:无论什么情况下都会调用两次超类型构造函数(一次在查收能见子类型原型时,一次是在子类型构造函数内部)
4.原型式继承
- Object.create()规范了原型式继承,可以接收两个参数(用作新对象原型的对象,为新对象定义额外属性的对象);
- 缺点:包含引用类型值的属性始终会共享相应的值。
5.寄生式继承
- 创建一个仅用于封装继承过程的函数,在函数内部增强对象,最后返回对象;
- 缺点:不能函数复用而降低效率。
6.寄生组合式继承
- 通过借用构造函数继承属性,通过原型链继承方法;
- 不必为了指定子类型的原型调用超类型的构造函数,我们只需要超类型原型的一个副本即可;使用寄生式继承来继承超类型原型,再将结果指定给子类型原型;
- 只调用了一次超类型构造函数。
--摘自《javascript高级程序设计》
js继承方式(es5)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。