首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS精粹】原型链继承构造函数继承的 “毛病”

构造函数继承 构造函数继承,也叫做:“盗用构造函数”,“对象伪装”或“经典继承”。 基本思路:在子类构造函数中用 apply()和 call()方法调用父类构造函数。...,但是它也有它的问题,也是使用构造函数模式自定义类型的问题, 即:必须在构造函数中定义方法(在原型上定义方法,子类是访问不到的),函数不能重用。...思路是:使用原型链继承原型上的属性和方法,而通过构造函数继承实例属性。...,总结起来就是,属性(特别是引用值)通过构造函数继承,而公用的、需要复用的方法用原型链去继承!!...说实话,JS 继承真的很奇怪。。。并不是面向对象语言,又要通过原型链去模拟面向对象,真的很多小坑的点需要去注意。

1.2K20

JavaScript构造函数继承

现在有一个"动物"对象的构造函数。 function Animal(){ this.species = "动物"; } 还有一个"猫"对象的构造函数。...一、 构造函数绑定 使用 call 或 apply 方法,将父对象的构造函数绑定在子对象上,即在子对象构造函数中加一行: function Cat(name,color){ Animal.apply...Cat.prototype.constructor = Cat; 任何一个 prototype 对象都有一个 constructor 属性,指向它的构造函数。...alert(cat1.constructor == Animal); // true 这显然会导致继承链的紊乱(cat1明明是用构造函数Cat生成的),因此需要手动纠正,将 Cat.prototype...使用时这样写: extend2(Cat, Animal); var cat1 = new Cat("AA猫","黑色"); alert(cat1.species); // 动物 至于非构造函数继承

94110
您找到你想要的搜索结果了吗?
是的
没有找到

ES6构造函数继承

构造函数继承的概念构造函数继承是一种通过创建子类来继承父类的属性和方法的方式。通过构造函数继承,子类可以获得父类的实例属性,并且可以调用父类的构造函数来初始化这些属性。...这种继承方式允许子类扩展父类的功能,并添加自己的属性和方法。构造函数继承的关键在于使用super()函数在子类的构造函数中调用父类的构造函数。...语法ES6中构造函数继承的语法如下:class ChildClassName extends ParentClassName { constructor(/* 子类构造函数参数 */) { super...然后,在子类的构造函数中使用super()函数来调用父类的构造函数。这样可以确保子类继承了父类的属性,并完成了属性的初始化。示例让我们通过一些示例来理解ES6中构造函数继承的使用。...通过构造函数继承,子类Child获得了两个父类的属性和方法。我们创建了一个Child类的实例,并访问了继承的属性name和age。

33130

JavaScript如何借用构造函数继承

这篇文章主要介绍了JavaScript如何借用构造函数继承,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 借用构造函数继承是在子类型构造函数的内部调用超类型构造函数...借用构造函数继承的优势是可以在子类型构造函数中向超类型构造函数传递参数,例如以下代码: ?...instance = new SubType(); console.log(instance.name); //nick console.log(instance.age); //20 借用构造函数继承的问题...:用构造函数继承并不能继承到超类型原型中定义的方法,例如以下代码,在girlFriends构造函数的原型中添加sayHello方法: ?...girlFriend.prototype.sayHello = function(){ console.log('hello'); } 继承它的子类构造函数的实例并不能调用到这个sayHello

86520

C++11继承构造函数

更为巧妙的是,C++11标准规定,继承构造函数与类的一些默认函数(默认构造、析构、拷贝构造函数等)一样,是隐式声明,如果一个继承构造函数不被相关代码使用,编译器不会为其产生真正的函数代码。...(2)构造函数拥有默认值会产生多个构造函数版本,且继承构造函数无法继承基类构造函数的默认参数,所以我们在使用有默认参数构造函数的基类时就必须要小心。...(3)多继承的情况下,继承构造函数会出现“冲突”的情况,因为多个基类中的部分构造函数可能导致派生类中的继承构造函数函数名、参数(即函数签名)相同。...C(int) C(int i):A(i),B(i){} }; 为避免继承构造函数冲突,可以通过显示定义继承类冲突的构造函数,组织隐式生成相应的继承构造函数。...此外,使用继承构造函数时,还需要注意以下几点: (1)如果基类构造函数被申明为私有成员函数,或者派生类是从基类中虚继承的 ,那么就不能在派生类中申明继承构造函数; (2)一旦使用继承构造函数,编译器就不会再为派生类生成默认构造函数

1.8K20

JavaScript原型链继承与盗用构造函数继承

这个就是继承。我们直接上干货。 原型链继承 原型链继承js中的主要继承方式,它的基本思想就是通过原型继承多个引用类型的属性和方法。...对于属性和方法一直会持续到原型链末端 原型链虽然是比较强大的继承实现工具,但是它里面所有的引用值都是实例间共享的,而且子类不能向父类传参,一般原型链也不会被单独使用,我们可以通过盗用构造函数配合来解决这些问题...盗用构造函数 盗用构造函数有时候也被一些人叫做“对象伪装”或“经典继承”。这个思路很简单,在字类构造函数中调用父类构造函数。我们可以用.call()和.apply()将父类构造函数引入子类函数。...name,在SubType构造函数调用SuperType的时候传入了这个参数。...盗用构造函数也有一定的问题 1、只能继承父类构造函数的属性。 2、无法实现构造函数的复用。(每次用每次都要重新调用) 3、每个新实例都有父类构造函数的副本,臃肿。

38520

js构造函数

//构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg...,在构造函数创建的每个实例中都会包含同样的私有和特权成员的副本, //因而实例越多占用的内存越多  } //公有方法 //适用于通过new关键字实例化的该对象的每个实例 //向prototype...中添加成员将会把新方法添加到构造函数的底层中去  myObject.prototype.sayHello = function(){      alert('hello everyone!')...(m1.name); //undefined, 静态属性不适用于一般实例 //console.log(m1.constructor.name); //china, 想访问类的静态属性,先访问该实例的构造函数...(类函数)的方法(函数) //m1.sayHello(); //hello everyone, myObject类的prototype原型下的方法将会被实例继承 //myObject.sayHello

2.7K10

js 中的构造函数构造函数作用,构造函数和普通函数的区别

构造函数 在 JavaScript 中,用 new 关键字来调用的函数,称为构造函数构造函数首字母一般大写(规范)。...并且该对象继承函数的原型; 属性和方法被加入到this引用的对象中; 隐式返回this对象(如果没有显性返回其他对象) 简单的说 用new调用构造函数,最大特点为,this对象指向构造函数生成的对象...当你需要大批量的写对象的时候,就需要用到构造函数,它可以方便创建多个对象的实例,并且创建的对象可以被标识为特定的类型,可以通过继承扩展代码 举个例子,我们要录入很多同学的个人信息,那么我们可以创建一些对象...6、 构造函数和普通函数的区别 1、构造函数也是一个普通函数,创建方式和普通函数一样,但构造函数习惯上首字母大写。 2、调用方式不一样。...(ES6 中 class 与构造函数的关 系,通过class定义的类 和通过构造函数定义的类 二者本质相同。并且在js执行时,会将第一种转会为第二种执行。

3.4K10

js构造函数的理解

作为原型和原型链的基础,先了解清楚构造函数以及它的执行过程才能更好地帮助我们学习原型和原型链的知识。 1、什么是构造函数 2、为什么要使用构造函数?...3、构造函数的执行过程 4、构造函数的返回值 5、构造函数首字母必须大写吗? 6、不用new关键字,直接运行构造函数,是否会出错?如果不会出错,那么,用new和不用new调用构造函数,有什么区别?...1、什么是构造函数 在 JavaScript 中,用 new 关键字来调用的函数,称为构造函数构造函数首字母一般大写 2、为什么要使用构造函数?...以上就是构造函数的整个执行过程。 4、构造函数的返回值 构造函数执行过程的最后一步是默认返回 this 。言外之意,构造函数的返回值还有其它情况。下面我们就来聊聊关于构造函数返回值的问题。...并且该对象继承函数的原型; 属性和方法被加入到this引用的对象中; 隐式返回this对象(如果没有显性返回其他对象) 用伪程序来展示上述变化: function Person(name){ //

2.1K31

“工厂、构造、原型” 设计模式与 JS 继承

这是我参与「掘金日新计划 · 6 月更文挑战」的第16天,点击查看活动详情 序言 我们在前一篇文章《JS精粹,原型链继承构造函数继承的 “毛病”》 ,提到了:原型链继承构造函数继承、组合继承; 在另一篇文章...《蓦然回首,“工厂、构造、原型”设计模式,正在灯火阑珊处》,提到了:我们用于创建对象的三种设计模式:工厂设计模式、构造设计模式、原型设计模式; 至此,我们可以明显的感受到:JS 要实现面向对象(继承的能力...),离不开这 3 种设计模式; 原型链 + 构造函数 = 组合继承 本篇带来一个新的继承方式:寄生继承,它由工厂模式和构造函数模式组成,即 工厂+构造函数 = 寄生继承 正文 正是由于:原型链继承构造函数继承的...构造函数继承:子类不能访问父类原型上的方法。...:工厂、构造、原型设计模式; 原型链 + 构造函数 = 组合继承 工厂+构造函数 = 寄生继承; 组合继承和寄生继承是最常用的两种继承方式。

1K30

JS高级——构造函数和原型

概述 在典型的OOP的语言中(如Java),都存在类的概念,类就是对象的模板,对象就是类的实例,但在ES6之前,JS中并没有引入类的概念。...在JS中,使用构造函数要注意以下两点: 构造函数用于创建某一类对象,其首字母要大写。 构造函数要和new一起使用才有意义。...ES6之前并没有给我们提供 extends继承,我们可以通过构造函数+原型对象模拟实现继承,被称为组合继承。...借用构造函数继承父类型属性 核心原理:通过 call()把父类型的this指向子类型的 this,这样就可以实现子类型继承父类型的属性。...一般情况下,对象的方法都在构造函数的原型对象中设置,通过构造函数无法继承父类方法。

1.4K10

JS高级」构造函数和原型

1.3构造函数的问题 构造函数方法很好用,但是存在浪费内存的问题。...1.8构造函数实例和原型对象三角关系 构造函数的prototype属性指向了构造函数原型对象; 实例对象是由构造函数创建的,实例对象的__proto__属性指向了构造函数的原型对象; 构造函数的原型对象的...this指向了对象o, 2.2子构造函数继承构造函数中的属性 先定义一个父构造函数 再定义一个子构造函数构造函数继承构造函数的属性(使用call方法) // 1....; } // 2 .子构造函数 function Son(uname, age, score) { // this 指向子构造函数的对象实例 // 3.使用call方式实现子继承父的属性...先定义一个父构造函数 再定义一个子构造函数构造函数继承构造函数的属性(使用call方法) // 1.

1.5K50

【C++】继承 ⑦ ( 继承中的对象模型分析 | 继承中的构造函数和析构函数 )

, 还有一个自己的 int z 成员 , 在内存中是 3 个 int 类型的空间 ; 3、问题引入 - 派生类对象构造函数和析构函数调用 上述 继承 的过程中 , 每一层继承 , 都继承了上一级 父类的...---- 1、子类构造函数与析构函数调用顺序 继承中的构造函数和析构函数 : 子类构造 : 子类对象 进行 构造 时 , 需要调用 父类 的 构造函数继承自父类的 成员变量 进行 初始化 操作...; 构造函数 调用顺序如下 : 构造时 , 先调用 父类 的构造函数 , 构造继承自父类的成员 ; 然后 , 再调用 子类 的 构造函数 , 构造 子类 自己定义的成员 ; 子类析构 : 子类对象...; 然后 , 再调用 父类 的 析构函数 , 析构 继承自父类的成员 ; 2、子类构造函数参数列表 如果 父类 的 构造函数 有 参数 , 则 需要再 子类 的 初始化列表中 显示调用 该有参构造函数...如果继承 A 类 , 如果 A 类有默认的构造函数 , B 类的构造函数可以这么写 , 不显式调用 A 类的构造函数 , 默认调用 A 类的 无参 默认构造函数 ; class B : public

18440

Javascript面向对象编程(二):构造函数继承

今天要介绍的是,对象之间的"继承"的五种方法。 比如,现在有一个"动物"对象的构造函数。   ...function Animal(){     this.species = "动物";   } 还有一个"猫"对象的构造函数。   ...一、 构造函数绑定 第一种方法也是最简单的方法,使用call或apply方法,将父对象的构造函数绑定在子对象上,即在子对象构造函数中加一行:   function Cat(name,color){...alert(cat1.constructor == Animal); // true 这显然会导致继承链的紊乱(cat1明明是用构造函数Cat生成的),因此我们必须手动纠正,将Cat.prototype...extend2(Cat, Animal);   var cat1 = new Cat("大毛","黄色");   alert(cat1.species); // 动物 (本系列未完,请继续阅读第三部分《非构造函数继承

1.1K80

深入理解javascript中的继承机制(4)多继承寄生式继承借用构造函数借用构造函数并且复制原型以上

首先将已有的对象作为新对象的原型,继承它的属性,我们调用了之前的objec函数 然后再给他添加其他属性与方法 借用构造函数 这种继承模式中,就是子对象的构造函数中调用父对象的构造函数,通过apply和...call和apply构造函数是什么呢?实际就是他们可以让一个一个对象去借用另一个对象的方法,并为己所用,这是一种非常简单的代码重用的方法,实质上就是去改变函数的this值。...这样的话,triangle对象会继承Shape构造函数中的属性,但不会继承原型中的属性。...(); Triangle.prototype.name = 'Triangle'; 但这样有一个缺点,我们通过调用父类的构造函数继承了父类的自身属性,通过原型继承了父类的自身属性和原型,这样自身属性实际上就被覆盖了两次...下面这个模式就可以更好的解决这个问题 借用构造函数并且复制原型 其实解决上面那个自身属性被继承两次的问题也很简单,我们首先调用apply函数继承父类的自身属性,然后在复制原型属性就可以了,这个方法我们之前已经讨论过就是

65110

【Kotlin】Kotlin 类的继承 一 ( 类继承基本方式 | final 关键字 | 子类主构造函数 | 子类次构造函数 )

继承基本方式 II . 使用 final 禁止类继承 / 方法重写 III . 父类没有主构造函数 IV . 父类有主构造函数 V . 父类构造函数与子类构造函数总结 I ....类继承基本方式 ---- 0 ....类继承格式 : 使用 " : " 继承父类 ; 如果该父类有主构造函数 , 那么子类必须至少有一个主构造函数或次构造函数 , 子类的构造函数下面会根据不同情况详细解析 ; //注意这里的父类构造函数需要实际调用...类继承限制 : 子类使用 : 父类 ( 父类构造函数参数列表 ) ① 类继承限制 : 只有被 open 修饰的类 , 才能有子类继承该类 , 普通的类不允许被继承 ; ② 类方法被重写限制 : 只有被...父类构造函数与子类构造函数总结 ---- 子类构造函数最终委托 : 子类的构造函数归根到底都要委托给父类的主构造函数 ; ① 子类主构造函数 : 假如子类有主构造函数 , 该主构造函数肯定要委托父类的主构造函数执行

1.1K10

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券