开发者社区> 好程序员> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

好程序员web前端教程之JS继承实现方式解析

简介:
+关注继续查看

  好程序员web前端教程之JS继承实现方式解析,JS是Web前端三要素之一,也是每一个初学前端的同学遭遇的第一条拦路虎。很多人反应JS学习不易,各类知识点概念及应用常常让人抓耳挠腮。在接下来的北京Web前端进阶课中,好程序员小编就给大家简单介绍一下JS的继承方式。

  什么是继承?
  继承就是让一个类型(可以通过构造函数或者class来定义)的对象能够访问另外一个类型的属性和方法,它是类和类之间的一种关系,通常说子类继承父类。但这里容易出现一个误区:认为实例继承了某个类,某人有响应的属性和方法是因为他继承人类,这种说法是错误。
  实现继承的方式有很多种,本次课程中小编给大家分享四种:借助构造函数实现继承、原型继承、组合继承、ES6继承。
  1、借助构造函数实现继承
  function Person(name,age){ //定义了一个父类
  this.name = name;
  this.age = age;
  this.sayHello = function(){
  console.log(this.name);
  }
  }
  function Male(name,age){ //定义了一个子类 男性类
  //继承父类,让子类具有相应的属性和方法
  //call或者apply的用法
  //构造函数里的this指向实例
  Person.call(this,name,age);
  this.hx = "true";//除了继承过来的属性和方法,还能添加针对于子类自身的属性和方法
  }
  function FeMale(name,age){ //定义了一个子类 女性类
  Person.call(this,name,age);
  this.hj = "no";
  }
  var male = new Male("chenjinfeng",20);
  male.sayHello();
  2、原型继承
  function Person(){
  }
  Person.prototype.name = "john";
  Person.prototype.age = 20;
  Person.prototype.sayHello = function(){
  console.log(this.name);
  }
  function Male(){
  }
  Male.prototype = new Person();//Male.prototype.__proto__ == Person.prototype 通过这行代码就实现继承
  //查找流程 male的__proto__(Male.prototype)上面有没有sayHello,
  //如果没有继续查找 male.__proto__.__proto__(Male.prototype.__proto__) 就是查找 Person.prototype
  var male = new Male();
  male.sayHello();
  3、组合继承
  function Person(name,age){
  this.name = name;
  this.age = age;
  }
  Person.prototype.sayHello = function(){
  console.log(this.name);
  }
  function Male(name,age){
  Person.call(this,name,age);//只能继承实例属性
  }
  //只考虑继承原型方法 是不是就可以了 让Male的原型对象也有Person原型对象上的方法
  /* Male.prototype = Person.prototype;
  //sayHi方法是我子类独有的方法
  Male.prototype.sayHi = function(){
  console.log("hi");
  }
  var male = new Male("john",20);
  male.sayHello();
  var person = new Person("aa",22);
  person.sayHi();//完了,父类居然能访问子类的方法,继承彻底乱了,原因是 Male.prototype 和 Person.prototype指向一样,任何一方改变,都会影响另一方 */
  for(let attr in Person.prototype){
  Male.prototype[attr] = Person.prototype[attr];
  }
  Male.prototype.sayHi = function(){
  console.log("hi");
  }
  var male = new Male("john",20);
  male.sayHello();
  male.sayHi();
  var person = new Person("aa",22);
  person.sayHi();
  4、ES6继承
  class Person{
  constructor(name,age){
  this.name = name;
  this.age = age;
  }
  sayHello(){
  console.log(this.name);
  }
  //扩展,定义类方法
  static foo(){
  console.log("这是类方法,不是实例方法");
  }
  }
  //通过extends这个关键字实现继承
  class Male extends Person{
  constructor(name,age){
  super(name,age);//1.创建this对象2.super指向父类的构造函数
  this.sexy = "男";//添加子类的实例属性
  }
  //在子类的原型方法里使用了父类的原型方法
  sayHi(){
  console.log("hi");
  super.sayHello();//super指向谁?指向父类的原型对象
  }
  static foo1(){
  super.foo(); //super指向父类
  }
  }
  var male = new Male("john",20);
  //male.sayHello();
  male.sayHi();
  Male.foo1();

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
好程序员web前端教程之CSS3渐变
好程序员web前端教程之CSS3渐变,CSS3渐变(gradient)可以让你在两个或多个指定的颜色之间显示平稳的过渡。 以前,你必须使用图像来实现这些效果,现在通过使用 CSS3 的渐变(gradients)即可实现。
949 0
好程序员web前端分享CSS3文本属性
浏览器前缀的简介及应用好程序员web前端分享css3文本属性,某些CSS属性还只是最新版的预览版,并未发布成最终的正式版,而大部分浏览器已经为这些属性提供了支持,但这些属性是小部分浏览器专有的;有些时候,有些浏览器为了扩展某方面的功能,它们会选择新增的一些CSS属性,这些自行扩展的CSS属性也是浏览器专属的。
956 0
好程序员web前端教程分享CSS元素类型
好程序员web前端教程分享CSS元素类型学习目标1、元素类型分类依据和元素类型分类2、元素类型的转换3、inline-block元素类型的应用4、置换和非置换元素的概念和应用案例一、元素类型分类依据和元素类型分类根据css显示分类,XHTML元素被分为三种类型:块状元素,内联元素1.
1090 0
好程序员web前端教程分享CSS预编译器的再次理解
  好程序员web前端教程分享CSS预编译器的再次理解:我所理解的css预编译器   基于css的,能让css也有一种编程语言范。解决了css的诸多问题,如css模块化、无法嵌套书写、没有变量。   css模块化   这个对于项目公司的项目来说,非常的重要。
902 0
好程序员web前端培训之CSS基础知识之position
 好程序员web前端培训之CSS基础知识之position   CSS定位机制   标准文档流(Normal flow)   浮动定位(Floats)   绝对定位(Absolute positioning)   标准文档流   从上到下,从左到右,输出文档内容   由块级元素和行级元素组成  ...
3247 0
好程序员解析Web前端中的IoC是什么
  好程序员解析Web前端中的IoC是什么,今天要为大家分享的文章就是关于对web前端中的 IoC的解释。Web前端技术越来越火,前端应用在不断壮大的过程中,内部模块间的依赖可能也会随之越来越复杂,模块间的 低复用性 导致应用 难以维护,不过我们可以借助计算机领域的一些优秀的编程理念来一定程度上解决这些问题,下面我们就来一起看一看IoC。
1035 0
好程序员Web前端教程分享Vue学习心得
  好程序员Web前端教程分享Vue学习心得,Vue是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。
894 0
好程序员web前端教程分享网页设计需要学那些东西?
**好程序员**web前端教程分享网页设计需要学那些东西:初次接触或者想要进入网页设计行业的朋友会经常分不清楚web前端与网页设计之间的区别,不知道网页设计要学什么,web前端要学什么,因此感到很迷茫,下面老师就来跟大家讲解下这两个方向分别要学什么。
2533 0
+关注
333
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载