给大家分享一个用原生JS编写的拖拽及拖拽方法继承的 小Demo,代码如下。 #div1 { width: 100px; height: 100px;...= function () { that.fnUp(); }; }; // 拖拽父级对象原型上添加鼠标移动时的方法...function LimitDrag(id) { // 调用父级对象 Drag.call(this, id); }; // 继承父级对象的原型...new Drag('div1'); // div2在拖动过程中通过将方法改写加上边界限制 new LimitDrag('div2
方式一:原型链继承特点:实例可继承的属性有:实例的构造函数的属性,父类构造函数属性,父类原型的属性。(新实例不会继承父类实例的属性!)...Child.prototype = new Parent()const c = new Child();console.log(c) // Child { name: 'zs', age: 20 }方式二:借用构造函数继承特点...:可以向父类构造函数传参 缺点:不能继承父类构造函数的原型function Parent(name) {this.name = name}function Child() {Parent.call(this...'lisi')this.age = 20}const c = new Child();console.log(c) // Child { name: 'lisi', age: 20 }方式三:组合式继承...:原型链继承+构造函数继承function Parent(name) {this.name = name}function Child(name) {Parent.call(this, name)this.age
一、原型链 学过java的同学应该都知道,继承是java的重要特点之一,许多面向对象的语言都支持两种继承方式:接口继承和实现继承,接口继承只继承方法签名,而实现继承则继承实际的方法,在js中,由于函数没有签名...,融合了它们的优点,现在已经成为js中最常用的继承方法。...寄生式继承 寄生式继承其实和我们前面说的创建对象方法中的寄生构造函数和工程模式很像,创建一个仅用于封装继承过程的函数,该函数在内部以某种方法来增强对象,最后再返回该对象。...寄生组合式继承 组合继承是js中最经常用到的一种继承方法,而我们前面也已经说了组合继承的缺点,组合继承需要调用两次超类型构造函数,一次是在创建子类型原型的时候,另一次是在子类型构造函数内部,子类型最终会包含超类型对象的全部实例属性...但是呢,使用extends实现继承的时候,还是有几点需要注意的问题,子类在继承父类的时候,子类必须在constructor方法中调用super方法,否则新建实例时会报错,这是因为子类自己的this对象,
new per.talk = function () { console.log("我是静态方法") } // 调用静态方法 per.talk() // 通过原型链拓展属性和方法 // 原型链上的属性会被多个实例共享...Person.prototype.sex = "男" Person.prototype.work = function () { console.log(this.name + "在工作") } per.work() 类的继承...对象冒充继承 // 对象冒充继承 function Woman() { //对象冒充可以继承函数的属性和方法,无法继承原型链上的 Person.call(this) } var wom...= new Woman() wom.run() //父类函数里的方法 原型链继承 // 原型链继承 function Man() {} // 原型链可以继承函数和原型链上的属性和方法 Man.prototype...= new Person() var man = new Man() man.run() //父类函数里的方法 man.work() //父类原型链里的方法 子类给父类传参 对象冒充+原型链 function
文章目录 一、基本代码 二、实现继承的方法: 1.原型链继承 2.构造继承: 3.实例继承 4.拷贝继承: 5.组合继承: 6.寄生组合继承: 7.class – extends – – ES6 一...,也是父类的实例 父类新增原型方法/原型属性,子类都能访问的到 简单 缺点 要想为子类新增属性和方法,必须要在new Animal()这样的语句之后执行,不能放到构造器中 无法实现继承多个 来自原型对象的所有属性被所有实例共享...(call多个父类对象) 缺点: 实例并不是父类的实例,只是子类的实例 只能继承父类的实例属性和方法,不能继承原型属性/方法 无法实现函数复用,每个子类都有父类实例函数的副本,影响性能 ---- 3.实例继承...,可以继承实例属性/方法,也可以继承原型属性/方法 既是子类的实例,也是父类的实例 不存在引用属性共享问题 函数可复用 可传参 缺点: 调用了俩次构造函数,生成了俩份实例(子类实例将子类原型上的那份屏蔽了...) ---- 6.寄生组合继承: //核心:通过寄生方式,砍掉父类的实例属性,这样,在调用俩次父类的构造的时候,就不会初始化俩次实例方法/属性,避免了组合继承的缺点。
在es6中class可通过关键词extends来实现继承,es5则是修改原型链来实现继承的。...有一个注意点:就是子类在constructor方法中调用super,super就是父类的构造函数,我们必须先构造父类,才能使用子类。...但是如果是函数,使用this或者super都是可以调用的到,比如在constructor方法中调用了父类的rotate方法,这里使用this.rotate()或者super.rotate()都是可以的,...es5中的继承 es5中的继承则是让某个构造函数的原型对象等于另一个类型的实例,这样实现的继承。...();//使用父类的方法 相信大家都可以看懂,es5的继承就让子类的prototype等于父类的实例,即可完成继承。
function Student(myName, myAge, myScore) { Person.call(this,myName,myScore);//在子类中通过...call/apply方法借助父类的构造函数 //1`改变函Person的this指向,使之指向Student; } Student.prototype=...console.log(this.name, this.age); } } /* 1.在ES6中如何继承...1.1在子类后面添加extends并指定父类的名称 1.2在子类的constructor构造函数中通过super方法借助父类的构造函数 */...// 以下代码的含义: 告诉浏览器将来Student这个类需要继承于Person这个类 class Student extends Person { constructor
arr = new Array(); 3.使用 Object.create() 这个方法有两个参数,第一个参数是这个对象的原型,第二个参数用以对对象的属性进行进一步描述(可选) var obj = Object.create...Object的属性,并具有obj.x = 1 的属性值 但当参数为null时,obj1则是一个没有原型的新对象,不会继承任何东西,甚至没有初始的toString()方法。...null中继承 throw TypeError(); } if(Object.create){ //如果有这个方法就直接使用 return Object.create...== null){ // 不能从null中继承 throw TypeError(); } if(Object.create){ //如果有这个方法就直接使用...;在JS中,只有在查询属性时才会体会到继承的存在,而设置属性则和继承无关。
,但是问题是父类原型的属性无法继承 方法二: 借助原型链 function Parent (sex) { this.name = 'zxx' this.sex = sex } Parent.prototype.test...方法五(推荐使用): 组合继承的优化1(寄生组合式继承) 这种方式的高效率体现它只调用了一次 Parent 构造函数,并且因此避免了在 Child.prototype 上面创建不必要的、多余的属性。...// super是指向父类的prototype对象,即Person.prototype, // 父类的方法是定义在父类的原型中,而属性是定义在父类对象上的,所以需要把属性定义在原型上。...不过这里加了一个Object.setPrototypeOf(subClass, superClass),是用来继承父类的静态方法。这也是原来的继承方式疏忽掉的地方。...__proto__ = superClass; } 继承的最大问题在于:无法决定继承哪些属性,所有属性都得继承。
,不能继承原型属性/方法。...中extends继承,眼过千遍,不如手写一遍。...第二种情况,super作为对象时,在普通方法中,指向父类的原型对象;在静态方法中,指向父类。...ES6 规定,在子类普通方法中通过super调用父类的方法时,方法内部的this指向当前的子类实例。...另外,在子类的静态方法中通过super调用父类的方法时,方法内部的this指向当前的子类,而不是子类的实例。
继承了父类自身的属性 继承了父类的原型属性(方法) 基于上面的问题,如果 Child.prototype 不指向 Parent的实例 new Parent(),而是指向 Parent.prototype...原型继承并不涉及到类,这里的对象都是继承自其他对象。...其实指的就是ES5里面的 Object.create() 方法。...—— 浅复制 & 深复制 继承的目的是为了实现代码复用,所以一个对象要从另一个对象中获取功能,把目标对象的属性和方法复制过来也是一种方法。...$.extend(child, parent); // 这时,child对象就具有parent对象的属性和方法,即被扩展(extend)了 ####浅复制 function clone(
1、继承关系内存解释 实际上在面向对象第一天的讲解当中,我们对内存方面做了一些隐瞒。因为除了Object类,所有的类都是有父类的。...Person(String name,int age) { this.name = name; this.age = age; } //get/set方法...北京海淀区上地7街晋福公寓"); } } 1.2、内存图 2、向上转型与向下转型内存解释 2.1、向上转型 当出现多态时,引用为Person类型,对象为Chinese对象,此时,由于Chinese中包含了父类所有成员...对外表现的就”像个父类对象一样”。 仅仅在调用方法时,会调用子类重写后的方法。...但是,如果没有出现多态,仅仅创建父类对象(如果父类不是抽象类的话),则为父类Person的引用指向Person的对象,没有子类的对象。
推荐阅读JS继承相关的书籍章节 《JavaScript高级程序设计第3版》第6章——面向对象的程序设计 6种继承的方案,分别是原型链继承、借用构造函数继承、组合继承、原型式继承、寄生式继承、寄生组合式继承...多重继承法 寄生继承法 构造器借用法 构造器借用与属性拷贝法 《ES6标准入门》第21章——class的继承 《深入理解ES6》第9章——JavaScript中的类 《你不知道的JavaScript》...上卷第6章——行为委托和附录A(ES6中的class) 总结 继承对于JS来说就是父类拥有的方法和属性、静态方法等,子类也要拥有。...子类中可以利用原型链查找,也可以在子类调用父类,或者从父类拷贝一份到子类等方案。 继承方法可以有很多,重点在于必须理解并熟。 悉这些对象、原型以及构造器的工作方式,剩下的就简单了。...回顾寄生组合式继承,主要就是三点: 子类构造函数的 proto指向父类构造器,继承父类的静态方法 子类构造函数的 prototype的 proto指向父类构造器的 prototype,继承父类的方法。
继承的含义: 继承是面向对象编程中的一个重要概念,通过继承可以使子类的实例使用在父类中定义的属性和方法。...JavaScript继承是一种允许我们在已有类的基础上创建新类的机制;它为子类提供了灵活性,可以重用父类的方法和变量。...: 不能继承原型上面的属性和方法 复制的处理,相当于在子类中实现了所有父类的方法,影响子类的性能。...这个例子的效率的体现在它只调用了一次父类的构造函数,这很大程度上面减少创建了不必要多余的属性。并且还能继承原型链上面的方法。这个方法是现在库的实现方法。...其实我们知道,class语法也是由es5语法来写的,其继承的方法和寄生组合式继承的方法一样。关于es6的类,我在代码自检的时候遇到的两个重点,值得注意下的是: 函数声明会提升,类声明不会。
考核内容: Class 的继承 题发散度: ★★ 试题难度: ★★ 解题思路: Class 表达式 ES6提供了更接近传统语言的写法,引入了Class(类)这个概念,作为对象的模板。...使用类时要注意以下几个方面: 定义“类”的方法的时候,前面不需要加上function这个关键字,直接把函数定义放进去了就可以了。另外,方法之间不需要逗号分隔,加了会报错。...构造函数的prototype属性,在ES6的“类”上面继续存在。事实上,类的所有方法都定义在类的prototype属性上面。 Object.assign方法可以很方便地一次向类添加多个方法。...类的内部所有定义的方法,都是不可枚举的(non-enumerable) 类的属性名,可以采用表达式。...[methodName] constructor方法是类的默认方法,通过new命令生成对象实例时,自动调用该方法。
大家好,又见面了,我是你们的朋友全栈君。 indexOf()简介 indexOf()是js中内置的方法之一,它的功能大家都很熟悉:简单来说就是得到数据的索引,对于正则不熟练的人,是个很不错的方法。...) 注:(暂不讨论两个参数时(第二个参数为查询的起始位置),以及lastIndexOf()) String类型使用indexOf(); String中的indexOf方法 (话不多说直接上代码,不跟你多...()是对数据进行了隐式类型转换的,如果参数是数值它会转换为字符来进行查询然后返回索引,本质原因是什么呢,那就是 我们js底层代码中String.prototype.indexOf()使用的是==进行比较判断...; Number类型的IndexOf() 醒醒,Number类型哪来的indexOf()方法,会直接报错的好吗, 如果想对数值类型的进行查询索引,可以将数值转换为字符再进行查询,方法有很多: –...()是不会进行隐式类型转换的,也就是说Array.prototype.indexOf()底层代码在实现的时候使用的是强等于=== 严格比较; 总结 string中indexOf() 会将数值参数转换为字符再查询索引
在理解继承之前,需要知道 js 的三个东西: 什么是 JS 原型链 this 的值到底是什么 JS 的new 到底是干什么的 一、什么是 JS 原型链 我们知道 JS 有对象,比如 var obj =...缺点: 只能继承父类的实例属性和方法,不能继承原型属性/方法 无法实现复用,每个子类都有父类实例函数的副本,影响性能 3、组合继承 组合上述两种方法就是组合继承。...用原型链实现对原型属性和方法的继承,用借用构造函数技术来实现实例属性的继承。...无法传递参数 另外,ES5中存在Object.create()的方法,能够代替上面的object方法。...其中constructor表示构造函数,一个类中只能有一个构造函数,有多个会报出SyntaxError错误,如果没有显式指定构造方法,则会添加默认的 constructor方法,使用例子如下。
JS实现继承的方式 构造函数继承 原型继承 组合(构造函数+原型)继承 Class继承 ---- 构造函数继承 构造函数继承的关键:在Child构造函数中执行Parent.call(this)...this.speak = function(){ console.log("Parent speak") } } // 缺点:new多个Child时, // Parent构造函数中的方法会在每个...组合继承 组合继承的关键: 1.属性使用构造函数继承 - 避免了原型继承中Parent引用属性被所有Child实例共享的缺陷。...2.方法使用过原型继承 - 避免了构造函数继承中方法重复拷贝、浪费内存的缺陷 function Parent(){ this.name = name; this.hobby = [];...因为子类没有自己的this对象,而是继承父类的this对象。如果不调用super函数,子类就得不到this对象。super()作为父类的构造函数,只能出现在子类的constructor()中。
JS 继承的7种方法,你学会了吗?...重新声明父类所定义的方法,无法复用。 三、组合继承 在前面两种方法中,都存在着一定的缺陷,所以很少会将它们单独使用。...实现方法 在组合继承的方法中我们 call 了一次,又 new 了一次,导致调用了2次父类,而在寄生式继承中,我们可以调用 API 来实现继承父类的原型 我们将两者结合在一起 不再采用 new 关键字来给改变原型...) } } 这样就实现了子类继承父类,这里的关键是需要在子类的 constructor 中添加一个 super 关键字 需要注意的是 子类中constructor方法中必须引用super方法,否则新建实例会报错...的东西还有很多,这里就不多说了 参考文献 《JavaScript 高级程序设计》 《JavaScript常见八种继承方案》 ---- 以上就是关于 JS 实现继承的 7 种方法了,当然还会有一些其他的继承方法
领取专属 10元无门槛券
手把手带您无忧上云