js中如何实现继承

js中的继承方式有多种,原型链继承通过子类型原型指向父类型实例实现,优点是实现简单且方法可复用,缺点是所有实例共享引用类型属性且无法向父类构造函数传参;构造函数继承通过在子类构造函数中调用父类构造函数解决属性共享问题,优点是可传递参数且属性独立,缺点是无法继承父类原型方法且方法不可复用;组合继承结合前两者优点,通过原型链继承原型方法、构造函数继承实例属性,实现了方法复用和属性独立,但父类构造函数被调用两次导致性能浪费;原型式继承基于现有对象创建新对象,适用于无需自定义类型的场景,但存在引用属性共享问题;寄生式继承在原型式继承基础上增强对象,适合临时扩展对象功能,但每次都会创建新方法;寄生组合式继承通过继承父类原型的副本来避免构造函数重复调用,解决了组合继承的性能问题,被认为是目前最理想的继承方式。选择继承方式应根据具体需求权衡。

js中如何实现继承

JS中的继承,简单来说,就是让一个对象拥有另一个对象的属性和方法。实现方式有很多,各有优劣,选择哪种取决于具体需求。

js中如何实现继承

解决方案:

实现JS继承的方法主要有以下几种:原型链继承、构造函数继承(也叫经典继承)、组合继承(原型链继承 + 构造函数继承)、原型式继承、寄生式继承、寄生组合式继承。

js中如何实现继承

如何理解原型链继承的优缺点?

原型链继承的核心在于利用原型对象,子类型的原型指向父类型的一个实例。这样,子类型就可以访问父类型原型上的属性和方法。

优点是实现简单,父类方法可以复用。

js中如何实现继承

缺点也很明显:

子类型的所有实例共享父类型原型上的属性,如果父类型原型属性是引用类型,一个实例修改了,其他实例也会受到影响。创建子类型实例时,没法给父类型构造函数传递参数。

function Parent() {  this.name = 'Parent';  this.colors = ['red', 'blue', 'green'];}Parent.prototype.sayName = function() {  console.log(this.name);}function Child() {  this.childName = 'Child';}Child.prototype = new Parent(); // 关键:让Child的原型指向Parent的实例Child.prototype.constructor = Child; // 修正constructor指向let child1 = new Child();child1.colors.push('black');let child2 = new Child();console.log(child2.colors); // ["red", "blue", "green", "black"]  child2也受到了影响

构造函数继承解决了什么问题,又带来了什么新问题?

构造函数继承,也叫经典继承,通过在子类型的构造函数中调用父类型的构造函数来实现。

优点:

解决了原型链继承中子类型实例共享父类型原型属性的问题。创建子类型实例时,可以向父类型构造函数传递参数。

缺点:

父类型的方法定义在构造函数中,每次创建子类型实例都会重新创建一遍,无法复用。父类型原型上的属性和方法,子类型无法访问。

function Parent(name) {  this.name = name;  this.colors = ['red', 'blue', 'green'];  this.sayName = function() { // 每次new Parent都会重新创建    console.log(this.name);  }}function Child(name) {  Parent.call(this, name); // 关键:在子类型构造函数中调用父类型构造函数  this.childName = 'Child';}let child1 = new Child('Child1');child1.colors.push('black');let child2 = new Child('Child2');console.log(child2.colors); // ["red", "blue", "green"] child2没有受到影响

组合继承为什么被认为是比较完善的继承方式?

组合继承结合了原型链继承和构造函数继承的优点,避免了它们的缺点。

思路是:使用原型链继承来实现对父类型原型属性和方法的继承,使用构造函数继承来实现实例属性的继承。

优点:

父类型的方法可以复用。子类型实例拥有各自独立的属性。创建子类型实例时,可以向父类型构造函数传递参数。

缺点:

父类型构造函数会被调用两次:一次是在设置子类型原型的时候,一次是在创建子类型实例的时候。 这导致父类的属性在子类实例和子类原型中都存在,造成一定的性能浪费。

function Parent(name) {  this.name = name;  this.colors = ['red', 'blue', 'green'];}Parent.prototype.sayName = function() {  console.log(this.name);}function Child(name, age) {  Parent.call(this, name); // 构造函数继承  this.age = age;}Child.prototype = new Parent(); // 原型链继承Child.prototype.constructor = Child; // 修正constructor指向let child1 = new Child('Child1', 10);child1.colors.push('black');let child2 = new Child('Child2', 12);console.log(child2.colors); // ["red", "blue", "green"]child1.sayName(); // Child1child2.sayName(); // Child2

原型式继承和寄生式继承有哪些应用场景?

原型式继承,不用创建构造函数,直接基于现有对象创建一个新对象。Object.create() 就是原型式继承的实现。

let person = {  name: 'Person',  friends: ['Shelby', 'Court', 'Van']};let anotherPerson = Object.create(person);anotherPerson.name = 'Greg';anotherPerson.friends.push('Rob');let yetAnotherPerson = Object.create(person);yetAnotherPerson.name = 'Linda';yetAnotherPerson.friends.push('Barbie');console.log(person.friends); // [ 'Shelby', 'Court', 'Van', 'Rob', 'Barbie' ]

原型式继承的缺点和原型链继承类似,修改一个实例的引用类型属性,会影响到其他实例。

寄生式继承,在原型式继承的基础上,增强对象,返回一个新对象。

function createAnother(original) {  let clone = Object.create(original); // 通过调用函数创建一个新对象  clone.sayHi = function() { // 以某种方式增强这个对象    console.log('hi');  }  return clone; // 返回这个对象}let person = {  name: 'Person',  friends: ['Shelby', 'Court', 'Van']};let anotherPerson = createAnother(person);anotherPerson.sayHi(); // "hi"

寄生式继承的缺点是,每个对象都会创建一遍方法。

原型式继承和寄生式继承,主要用于不需要自定义类型,只是想得到一个对象的副本,并对其进行一些修改的场景。

寄生组合式继承如何解决组合继承的性能问题?

寄生组合式继承,被认为是目前最理想的继承方式。它解决了组合继承中父类构造函数被调用两次的问题。

核心思想是:不通过调用父类构造函数来给子类原型赋值,而是通过创建父类原型的副本来实现。

function inheritPrototype(child, parent) {  let prototype = Object.create(parent.prototype); // 创建父类原型的副本  prototype.constructor = child; // 修正constructor指向  child.prototype = prototype; // 将副本赋值给子类原型}function Parent(name) {  this.name = name;  this.colors = ['red', 'blue', 'green'];}Parent.prototype.sayName = function() {  console.log(this.name);}function Child(name, age) {  Parent.call(this, name);  this.age = age;}inheritPrototype(Child, Parent);let child1 = new Child('Child1', 10);child1.colors.push('black');let child2 = new Child('Child2', 12);console.log(child2.colors); // ["red", "blue", "green"]child1.sayName(); // Child1child2.sayName(); // Child2

inheritPrototype 函数起到了关键作用,它避免了调用 Parent 构造函数,只使用了 Parent.prototype 的副本。

选择哪种继承方式,取决于你的具体需求。 如果只是简单的想复用父类原型上的方法,原型链继承可以考虑。 如果需要传递参数,并且不关心方法复用,构造函数继承可以考虑。 如果追求更完善的继承方式,寄生组合式继承是更好的选择。

以上就是js中如何实现继承的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1512984.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 07:27:36
下一篇 2025年12月20日 07:27:46

相关推荐

  • CSS mask属性无法获取图片:为什么我的图片不见了?

    CSS mask属性无法获取图片 在使用CSS mask属性时,可能会遇到无法获取指定照片的情况。这个问题通常表现为: 网络面板中没有请求图片:尽管CSS代码中指定了图片地址,但网络面板中却找不到图片的请求记录。 问题原因: 此问题的可能原因是浏览器的兼容性问题。某些较旧版本的浏览器可能不支持CSS…

    2025年12月24日
    900
  • 为什么设置 `overflow: hidden` 会导致 `inline-block` 元素错位?

    overflow 导致 inline-block 元素错位解析 当多个 inline-block 元素并列排列时,可能会出现错位显示的问题。这通常是由于其中一个元素设置了 overflow 属性引起的。 问题现象 在不设置 overflow 属性时,元素按预期显示在同一水平线上: 不设置 overf…

    2025年12月24日 好文分享
    400
  • 网页使用本地字体:为什么 CSS 代码中明明指定了“荆南麦圆体”,页面却仍然显示“微软雅黑”?

    网页中使用本地字体 本文将解答如何将本地安装字体应用到网页中,避免使用 src 属性直接引入字体文件。 问题: 想要在网页上使用已安装的“荆南麦圆体”字体,但 css 代码中将其置于第一位的“font-family”属性,页面仍显示“微软雅黑”字体。 立即学习“前端免费学习笔记(深入)”; 答案: …

    2025年12月24日
    000
  • 为什么我的特定 DIV 在 Edge 浏览器中无法显示?

    特定 DIV 无法显示:用户代理样式表的困扰 当你在 Edge 浏览器中打开项目中的某个 div 时,却发现它无法正常显示,仔细检查样式后,发现是由用户代理样式表中的 display none 引起的。但你疑问的是,为什么会出现这样的样式表,而且只针对特定的 div? 背后的原因 用户代理样式表是由…

    2025年12月24日
    200
  • inline-block元素错位了,是为什么?

    inline-block元素错位背后的原因 inline-block元素是一种特殊类型的块级元素,它可以与其他元素行内排列。但是,在某些情况下,inline-block元素可能会出现错位显示的问题。 错位的原因 当inline-block元素设置了overflow:hidden属性时,它会影响元素的…

    2025年12月24日
    000
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 为什么使用 inline-block 元素时会错位?

    inline-block 元素错位成因剖析 在使用 inline-block 元素时,可能会遇到它们错位显示的问题。如代码 demo 所示,当设置了 overflow 属性时,a 标签就会错位下沉,而未设置时却不会。 问题根源: overflow:hidden 属性影响了 inline-block …

    2025年12月24日
    000
  • 为什么我的 CSS 元素放大效果无法正常生效?

    css 设置元素放大效果的疑问解答 原提问者在尝试给元素添加 10em 字体大小和过渡效果后,未能在进入页面时看到放大效果。探究发现,原提问者将 CSS 代码直接写在页面中,导致放大效果无法触发。 解决办法如下: 将 CSS 样式写在一个单独的文件中,并使用 标签引入该样式文件。这个操作与原提问者观…

    2025年12月24日
    000
  • 为什么我的 em 和 transition 设置后元素没有放大?

    元素设置 em 和 transition 后不放大 一个 youtube 视频中展示了设置 em 和 transition 的元素在页面加载后会放大,但同样的代码在提问者电脑上没有达到预期效果。 可能原因: 问题在于 css 代码的位置。在视频中,css 被放置在单独的文件中并通过 link 标签引…

    2025年12月24日
    100
  • 为什么在父元素为inline或inline-block时,子元素设置width: 100%会出现不同的显示效果?

    width:100%在父元素为inline或inline-block下的显示问题 问题提出 当父元素为inline或inline-block时,内部元素设置width:100%会出现不同的显示效果。以代码为例: 测试内容 这是inline-block span 效果1:父元素为inline-bloc…

    2025年12月24日
    400
  • css中有哪些属性可以继承

    css可以继承的属性:color、font、quotes、cursor、page、windows、text-indent、font-size、font-style、direction、line-height、word-spacing等等。 本教程操作环境:windows7系统、CSS3版、Dell …

    2025年12月24日
    000
  • css中哪些属性可以继承

    css中可以继承的属性有:text-indent、text-align、line-height、word-spacing、letter-spacing、text-transform、visibility、color、cursor等等。 本教程操作环境:windows7系统、CSS3版、Dell G3…

    2025年12月24日 好文分享
    000
  • css有继承关系吗

    css有继承关系。CSS继承是一种规则,它允许样式不仅应用于某个特定html标签元素,而且应用于其后代;也就是说:设置了上级(父级)的CSS样式,上级(父级)及以下的子级(下级)都具有此样式。 本教程操作环境:windows7系统、css3版、Dell G3电脑。 (学习视频分享:css视频教程) …

    2025年12月24日
    000
  • css中内联元素可继承的属性有哪些?

    css中内联元素可继承的属性有:text-shadow、line-height、word-spacing、letter-spacing、font-family、font-weight、font-size、font-style、font等等。 css中内联元素可继承的属性 1、内联元素可继承的文本系列…

    2025年12月24日
    000
  • CSS什么是继承?CSS如何使用?

    本篇文章给大家带来的内容是介绍css什么是继承?css如何使用?有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所助。 CSS的继承 css的继承指的是当标签具有嵌套关系时,内部标签自动拥有外部标签的不冲突的样式的性质。 在Css中有些属性不允许继承,例如,border属性没有继承性。多边框…

    好文分享 2025年12月24日
    000
  • css继承是什么意思?css哪些属性可以继承?

    在css的学习过程中,我们会遇到一些属性可以继承,那么,css中的继承是什么意思?有哪些属性可以继承呢?本篇文章就给大家来介绍一下css中继承性的内容。 我们定义css继承前,先来看一看HTML DOM(文档树),HTML DOM(文档树)是由html元素组成,文档树和家族树类似,也有祖先、后代、父…

    好文分享 2025年12月24日
    000
  • 关于CSS样式中大于号的使用及Css中处理继承方法

    继承给我们的程序带来一定的困扰,所以认真的学习继承的原理,下面有个不错的示例,一个处理继承的一个方法,感兴趣的朋友可以参考下 继承在一定程度上让程序在编写的过程中更加方便,但是有时候也会给我们的程序带来一定的困扰,所以认真的学习继承的原理,以及处理的方法很重要。下面是Css中处理继承的一个方法。 在…

    好文分享 2025年12月24日
    000
  • 对CSS继承的深度解析

      我酷爱模块化设计。长期以来我都热衷于将网站分离成组件,而不是页面,并且动态地将那些组件合并到界面上。这种做法灵活,高效并且易维护。   但是我不想我的设计看上去是由一些不相关的东西组成的。我是在创造一个界面,而不是一张超现实主义的照片。   很幸运的是,已经有一项叫做 CSS 的技术,就是特意设…

    2025年12月23日
    000
  • CSS 继承深度解析

      我酷爱模块化设计。长期以来我都热衷于将网站分离成组件,而不是页面,并且动态地将那些组件合并到界面上。这种做法灵活,高效并且易维护。   但是我不想我的设计看上去是由一些不相关的东西组成的。我是在创造一个界面,而不是一张超现实主义的照片。   很幸运的是,已经有一项叫做 CSS 的技术,就是特意设…

    2025年12月23日
    000
  • 关于CSS的优先级和继承问题

    text-align: center”>CSS的优先级和继承问题 ★css的冲突,即优先级  css本身的设置可以同时应用多个样式在同一个元素,此时样式之间可能出现冲突而达不到用户所想要的效果。★解决css冲突的优先级规则:  ● css层叠样式表引入方法的优先级:内联式>内…

    好文分享 2025年12月23日
    000

发表回复

登录后才能评论
关注微信