我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JS快速掌握ES6的class用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JS快速掌握ES6的class用法

1.如何构造?

先复习一下es5常用的构建类的方法:首先es5的写法使用原型进行对象的方法的,为什么不在构造函数里添加方法呢?因为实例化对象的时候,会重复的建立好多相同的方法,浪费资源。所以需要把对象的方法挂载到prtotype里。

关于new和this的绑定问题,可以大概简化为:

  • 首先通过new生成一个新的对象
  • 然后让这个对象绑定到构造函数的this中去
  • 然后绑定这个构造对象的原型对象上
  • 最后把这个对象返回给前面定义的对象

那么接下来看例子吧:


fuction Animal(name,age){
  this.name = name
  this.age = age
  
  // 这样是浪费资源的
  // this.eat = function(){
  //   console.log("今天我吃饭了")
  // }
}

// 正确做法
Animal.prototype.eat=function(){
  console.log("今天我吃饭了")
}

然后上ES6的class,class很明显就简化了这个操作


cosnt dog = new Animal("wangcai",2) // 会报错,ES6为了修改陋习,和let和const一样,class不会提升.

class Animal{
  constroctor(name,age){
    this.name = name 
    this.age = age 
  }
  
    eat(){
    console.log("今天我吃饭了")
  }
}

cosnt dog = new Animal("wangcai",2)  //正确位置

另外class还添加了静态方法,set,get等操作。


class Animal{
  constroctor(name,age){
    this.name = name 
    this.age = age 
  }
  
    eat(){
    console.log("今天我吃饭了")
  }
  

 set name(value){
    this.tempname ="老铁"+value
  }
  
  get name(){
    return this.tempname
  }
  
  static introuduce(){
    console.log("我现在是一个动物类")
  }
}

//set() get()
const dog = new Animal("giao",2)
dog.name="agiao" 
console.log(dog.name) // 老铁agiao

// 静态方法
Animal.introuduce() // 我现在是一个动物类

再说继承之前补充个小知识点,class的方法名可以通过计算属性的操作来命名


let tempname = "giao"
class Animal{
   constroctor(name,age){
    this.name = name 
    this.age = age 
  }
  
  [tempname](){
    console.log("一给我咧giao")
  }
}

const xiaoagiao = new Animal("giaoge",30)
xiaoagiao.giao() // 一给我咧giao

2.继承

回到继承这个问题,es5是怎么继承的呢?


function Animal( name ){
  this.name = name
}
Animal.prototype.break(){
  console.log("叫!")
}

function Dog( name, age ){
  Animal.call(this,name)
  this.age = age
}

Dog.prototype = new Animal()
Dog.prototype.constructor = Dog

那么这个叫组合继承,怎么个组合法呢?

属性方面的继承是借用继承,可以看到Animal.call(this,name)就是相当于把Animal这个函数在Dog的构造函数里调用了一遍而已。虽然属性他们没有原型链的链式联通,但是代码拿过来给Dog都跑了一遍,所以自然就继承了Animal的name属性。


Animal.call(this,name)

方法的继承是原型式继承,众所周知,一个函数会在创建的时候生成一个原型对象,这个函数的的一个protoype属性指向他的原型对象,原型对象的constructor属性指向这个函数。如果用new来新建这个函数的实例,这个实例会有一个__proto__的属性指向函数的原型对象。所以借用函数实例会指向函数原型对象这个特性,我们将被继承的函数实例化,然后将这个实例化的对象赋给继承的构造函数的prototype属性,这样就构成了一种链式结构。但同被继承的函数实例化是不具备constructor这个属性的,我们需要将他的constructor指向继承的构造函数。


Dog.prototype = new Animal()
Dog.prototype.constructor = Dog

所以按照这个套路,我们用es5的语法,将dog函数继承了Animal函数的name和break方法.

那么ES6是怎么做的呢?


class Animal{
  constructor( name ){
    this.name = name 
  }
  
  break(){
    console.log("叫!")
    }
}

class Dog extends Animal {
  constructor( name, age ){
    super(name)
    this.age=age
  }
}

现在只需要在声明Dog类的时候加一个extends Animal,然后再在constructor构造函数里加一个super就好了。

这个super(name)就相当于Animal.call(this,name)了。然后关于方法的问题,自然就不用担心了,extends自动就处理好了,就不用再去用prototype乱指了.

以上就是JS快速掌握ES6的class用法的详细内容,更多关于JS ES6的class用法的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JS快速掌握ES6的class用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

快速掌握VueRouter使用方法

VueRouter是Vue.js官方的路由管理器。它和Vue.js的核心深度集成,让构建单页面应用变得易如反掌。路由实际上就是可以理解为指向,就是我在页面上点击一个按钮需要跳转到对应的页面,这就是路由跳转
2023-01-09

快速掌握CSS框架的方法

简明易懂:CSS框架如何快速上手,需要具体代码示例简介:CSS框架是前端开发中常用的工具,它可以帮助我们快速构建美观且响应式的网页。然而,对于初学者来说,学习并使用CSS框架可能会有一定的困难。本篇文章将简要介绍CSS框架的基本概念,并提
快速掌握CSS框架的方法
2024-01-16

快速掌握Fedora 17的方法详解

要快速掌握Fedora 17,可以按照以下步骤进行:1. 下载和安装Fedora 17:首先,您需要从官方网站上下载Fedora 17的安装镜像文件。然后,将该镜像烧录到一张空白光盘或创建一个可引导的USB驱动器。最后,将该光盘或USB驱动
2023-09-23

快速掌握Node.js中setTimeout和setInterval的使用方法

Node.js和js一样也有计时器,超时计时器、间隔计时器、及时计时器,它们以及process.nextTick(callback)函数来实现事件调度。今天先学下setTimeout和setInterval的使用。 一、setTimeout
2022-06-04

Python如何快速上手? 快速掌握一门新语言的方法

那么Python如何快速上手?找来了一篇广受好评的新语言学习方法介绍,供大家参考。 听说,你决定要为你的 “技能树” 再添加一门特定的编程语言。那该怎么办呢? 在这篇文章中,作者提出了 12 项关于学习技术的建议。记住每个人学习的方式都不一
2022-06-04

深入解析Golang指针的用法,助你快速掌握

Golang指针用法实例解析,让你快速上手概述:在Go语言中,指针是一种特殊的变量类型,它存储了一个内存地址。通过指针,我们可以直接访问内存中的数据,能够在函数之间分享数据。指针功能强大且灵活,但也容易出错。本文将介绍Golang中指针的
深入解析Golang指针的用法,助你快速掌握
2024-01-24

快速掌握在Linux上安装Go语言的方法

在Linux上安装Go语言是开发者们开始使用这门编程语言的第一步。Go语言是一门由Google开发的开源编程语言,其简单易学的特点吸引了众多开发者的青睐。本文将介绍如何在Linux系统上快速安装Go语言,并提供具体的代码示例以帮助读者快速上
快速掌握在Linux上安装Go语言的方法
2024-03-13

快速掌握运用Python中len函数的技巧

快速掌握Python中len函数的使用技巧,需要具体代码示例Python是一种简洁、易读的编程语言,广泛应用于数据科学、机器学习、网络开发等领域。在Python中,len函数是一个非常常用且重要的函数之一。它用于返回一个对象(如字符串、列
快速掌握运用Python中len函数的技巧
2024-01-29

Java 语法快车:快速掌握编程语言的基本要素

变量与数据类型变量用于存储数据,而数据类型定义了变量可以存储的值的类型。Java 支持各种数据类型,包括基本类型(如 int、double、boolean)和引用类型(如 String、ArrayList)。了解每种数据类型的特性,如范围、默认值和操作,是理解 Java 程序的基础。表达式与运算符表达式是一组计算值的指
Java 语法快车:快速掌握编程语言的基本要素
2024-04-03

快速掌握Node.js环境的安装与运行方法

安装程序 NodeJS 提供了一些安装程序,都可以在 nodejs.org 这里下载并安装。 Windows 系统下,选择和系统版本匹配的 .msi 后缀的安装文件。Mac OS X 系统下,选择 .pkg 后缀的安装文件。 编译安装 Li
2022-06-04

快速掌握静态相对定位的技巧与方法

快速静态相对定位是网页开发中非常重要的一种定位方式。它可以使元素相对于其正常位置进行微调的同时,仍然保持在文档流中的位置。在本文中,我将详细介绍快速静态相对定位的使用方法,以及一些常见的应用场景。首先,我们需要了解快速静态相对定位的基本概
快速掌握静态相对定位的技巧与方法
2024-01-18

掌握PHP Class用法:提升代码的可维护性

PHP是一种广泛用于开发Web应用程序的编程语言,其中的Class是面向对象编程中非常重要的概念。正确地使用PHP Class能够提高代码的可维护性,使代码更加清晰、结构化,并且易于扩展和修改。下面将通过具体的代码示例来介绍如何掌握PHP
掌握PHP Class用法:提升代码的可维护性
2024-03-09

如何快速掌握Java中的搜索算法和排序算法

这篇文章主要介绍“如何快速掌握Java中的搜索算法和排序算法”,在日常操作中,相信很多人在如何快速掌握Java中的搜索算法和排序算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何快速掌握Java中的搜索算
2023-07-05

编程热搜

目录