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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介:

  好程序员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();

相关文章
|
24天前
|
前端开发 JavaScript
探索现代Web应用的微前端架构
【10月更文挑战第40天】在数字时代的浪潮中,Web应用的发展日益复杂多变。微前端架构作为一种新兴的设计理念,正逐步改变着传统的单一前端开发模式。本文将深入探讨微前端的核心概念、实现原理及其在实际项目中的应用,同时通过一个简单的代码示例,揭示如何将一个庞大的前端工程拆分成小而美的模块,进而提升项目的可维护性、可扩展性和开发效率。
|
15天前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
27 6
|
15天前
|
JavaScript
使用Node.js创建一个简单的Web服务器
使用Node.js创建一个简单的Web服务器
|
23天前
|
消息中间件 前端开发 JavaScript
探索微前端架构:构建现代Web应用的新策略
本文探讨了微前端架构的概念、优势及实施策略,旨在解决传统单体应用难以快速迭代和团队协作的问题。微前端允许不同团队独立开发、部署应用的各部分,提升灵活性与可维护性。文中还讨论了技术栈灵活性、独立部署、团队自治等优势,并提出了定义清晰接口、使用Web组件、状态管理和样式隔离等实施策略。
|
1月前
|
监控 前端开发 JavaScript
探索微前端架构:构建可扩展的现代Web应用
【10月更文挑战第29天】本文探讨了微前端架构的核心概念、优势及实施策略,通过将大型前端应用拆分为多个独立的微应用,提高开发效率、增强可维护性,并支持灵活的技术选型。实际案例包括Spotify和Zalando的成功应用。
|
2月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
147 3
|
1月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
156 45
|
8天前
|
前端开发 安全 JavaScript
2025年,Web3开发学习路线全指南
本文提供了一条针对Dapp应用开发的学习路线,涵盖了Web3领域的重要技术栈,如区块链基础、以太坊技术、Solidity编程、智能合约开发及安全、web3.js和ethers.js库的使用、Truffle框架等。文章首先分析了国内区块链企业的技术需求,随后详细介绍了每个技术点的学习资源和方法,旨在帮助初学者系统地掌握Dapp开发所需的知识和技能。
2025年,Web3开发学习路线全指南
|
15天前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
25 7
|
19天前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。