在ES5中,我们就知道JS是不支持面向对象的,所以用函数模拟了一个构造函数来实现类的。那么在ES6中,在ES5的原理基础上,将代码书写更为简单,明了。

一、怎样用ES6创建类?首先看一看例子:

 class Student {
constructor(name, age) {
this.name = name;
this.age = age;
}
sleep(){console.log(`xx在xx睡觉`);
};
}
let s = new Student("ax", 23);
console.log(s);

这里出现了关键词“class”,之后的Student为类的标识符,使用大驼峰命名法。这是类模板。

constructor()是类中必须存在的构造函数,若没有书写则会默认有一个空构造。在小括号内是类的参数,只要觉得有必要写入的参数都可以写。这是构造器。

二、new:new关键字,调用类。调用类时发生了什么?(这是面试常考题)

1、创建一个空的新对象
var obj = {};
2、将该对象的_proto_(隐式原型)指向创建该对象的类的原型对象
假设类叫做A,obj._proto_ = A.prototype
3、将构造函数环境中的this,指向该对象,执行构造函数中的代码
this = obj;(代码错误,理解环境)
4、返回刚刚的创建的新对象

三、在类中,常用get—set属性,获取和设置属性值,是可控的手段

例子
class Circle {
constructor(left, top, r) {
this.createNode(); //在类中调用创建节点
this.left = left;
this.top = top;
this.r = r;
this.appendToPage(); //将节点放入页面
}
createNode() {
const div = document.createElement("div"); //创建节点,放入div变量
this.node = div; //类的节点为div
};
appendToPage() {
document.body.appendChild(this.node);
}
get left() {
return this.left + this.r;
}
set left(value) {
this.node.style.left = value - this.r + "px"; //将圆心设为点
}
get top() {
return this.top + this.r;
}
set top(value) {
this.node.style.top = value - this.r + "px";
}
get r() {
return this.noed.offsetWidth / 2 + "px";
}
set r(value) { }
}

创建一个圆圈类,其中的位置和半径都用get-set属性设置,他们为一对使用。get()为调用,set()为更改属性值(有参数)。当我们操作实例对象的get set属性时,就相当于在不断的调用对应的get—set方法。

四、类的三大特征

(1)封装

隐藏内部细节,不暴露在外面;即,信息的隐藏。不关心具体怎样实现的,只需要知道能达到效果就行了

(2)继承

子类继承父类的“所有”属性和方法,并且拥有自己的属性和方法
不能指向性继承

【extends 扩展】
从子类,扩展到父类,即继承父类

【super 超类】

继承父类,只能写在子类第一行中,并且只能写一次

class Person{
constructor(name,age,gender){
this.name = name;
this.age = age;
this.gender = gender;
}
}
class Student extends Person{//学生类 扩展 至人类=>即 继承
constructor(name,age,gender,grade){
super(name,age,gender)//超类(父类),调用父亲的构造,实现父亲构造的继承
this.grade = grade;//用继承省去部分重复的
}
}

(3)多态

相同的行为,不同的、多种的实现,传的参数不一样,决定了实现方法不一样。

【重载】

JS自带,参数的不同,实现不同。通过if判断参数表

【重写】

父亲的行为,儿子重写一个,覆盖父亲的

例子:

创建图形类,三角形类为图形类的儿子,使用extends继承;三角形类有父亲没有的特性,因此创建createNode方法重写。

class Graph {
constructor(color, left, top) {
this.color = color;
this.left = left;
this.top = top;
this.node = null; //没有创建图形时,图形节点为空,之后重新赋值
}
} //三角形
class Triangle extends Graph {//继承
constructor(color, left, top, bottom, height) {
super(color, left, top)
this.bottom = bottom;
this.height = height;
this.init();
}
createNode() { //oo重写
this.node = document.createElement("p");
// this.node.style.backgroundColor = this.color;
this.node.style.left = this.left + "px";
this.node.style.top = this.top + "px";
this.node.style.borderBottom = this.height + "px" + " solid " + this.color;
this.node.style.borderLeft = this.bottom / 2 + "px" + " solid transparent";
this.node.style.borderRight = this.bottom / 2 + "px" + " solid transparent";
}
}

以上就是ES6的类的创建和使用。

(ES6)JavaScript中面向对象类的实现的更多相关文章

  1. javascript中面向对象的5种写法

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. JavaScript中面向对象的三大特性(一个菜鸟的不正经日常)

    经过几天的学习,把jQuery给啃会了,但是运用的还不算特别熟练,总感觉自己在JavaScript方面的基础十分欠缺,所以继续拾起JavaScript,开始更好的编程之旅~ 今天学的是JavaScri ...

  3. Javascript中的类实现

    Javascript本身并不支持面向对象,它没有访问控制符,它没有定义类的关键字class,它没有支持继承的extend或冒号,它也没有用来支持虚函数的virtual,不过,Javascript是一门 ...

  4. JavaScript中定义类的方式详解

    本文实例讲述了JavaScript中定义类的方式.分享给大家供大家参考,具体如下: Javascript本身并不支持面向对象,它没有访问控制符,它没有定义类的关键字class,它没有支持继承的exte ...

  5. JavaScript中创建类,赋值给ajax中的data参数

    缘由:因为要给根据是否选中checkbox来动态增加ajax中data的属性(ajax的data属性格式的几种方法,参考http://www.jb51.net/article/46676.htm) d ...

  6. JavaScript中的类

          JavaScript类的相关知识 1.例子 /* 例1 */// 定义一个构造函数function Range(from, to){ this.from = from; this.to = ...

  7. 《深入理解ES6》笔记—— JavaScript中的类class(9)

    ES5中的近类结构 ES5以及之前的版本,没有类的概念,但是聪明的JavaScript开发者,为了实现面向对象,创建了特殊的近类结构. ES5中创建类的方法:新建一个构造函数,定义一个方法并且赋值给构 ...

  8. (转载)JavaScript中面向对象那点事

    鉴于自己在JavaScript这方面比较薄弱,所以就找了一本书恶补了一下(被称为犀利书的JavaScript权威指南).书的内容虽然多了点,但这也充分说明了js中的东西还是挺多的.虽然我们的定位不是前 ...

  9. JavaScript中面向对象那点事

    鉴于自己在JavaScript这方面比較薄弱.所以就找了一本书恶补了一下(被称为犀利书的JavaScript权威指南).书的内容尽管多了点,但这也充分说明了js中的东西还是挺多的.尽管我们的定位不是前 ...

随机推荐

  1. SpringBoot2启动流程分析

    首先上一张图,图片来自 SpringBoot启动流程解析 本文基于spring-boot-2.0.4.RELEASE.jar包分析. 程序启动入口 public static void main(St ...

  2. python 实现整数的反转:给定一个整数,将该数按位逆置,例如给定12345变成54321,12320变成2321.

    给定一个n位(不超过10)的整数,将该数按位逆置,例如给定12345变成54321,12320变成2321. # 第一种方法,使用lstrip函数去反转后,数字前面的0 import math num ...

  3. STM32与STM8操作寄存器的区别

    在STM8中,由于STM8寄存器较少,在头文件中定义寄存器的时候不用采取任何形式的封装,所以操作寄存器的时候直接可以用如下方式处理:PB_DDR |=0x20; 但是在STM32中,由于其寄存器实在太 ...

  4. 模型正则化,dropout

    正则化 在模型中加入正则项,防止训练过拟合,使测试集效果提升 Dropout 每次在网络中正向传播时,在每一层随机将一些神经元置零(相当于激活函数置零),一般在全连接层使用,在卷积层一般随机将整个通道 ...

  5. 【重学Node.js 第4篇】实现一个简易爬虫&启动定时任务

    实现一个简易爬虫&启动定时任务 课程介绍看这里:https://www.cnblogs.com/zhangran/p/11963616.html 项目github地址:https://gith ...

  6. ELK学习实验013:ELK的一个完整的配置操作

    前面做了关于ELK组件的各个实验,但是并没有真正的把各个组件结合起来做一个实验,现在使用一个脚本简单的生成日志,模拟生产不断产生日志的效果 一 流程说明 使用脚本产生日志,模拟用户的操作 日志的格式 ...

  7. 《面试宝典》 2019年springboot面试高频题(java)

    前言 2019年已经成为了过去,借此机会想好好总结一下2019年项目研发的成效,看看在项目从无到有,都经历了那些变化?取得了哪些成果?踩过哪些坑?一个人.一个研发团队要想有质的飞跃,必须善于反思过去, ...

  8. 基于FPGA的SPI FLASH控制器设计

    1.SPI FLASH的基本特征 本文实现用FPGA来设计SPI FLASH,FLASH型号为W25Q128BV.支持3种通信方式,SPI.Dual SPI和Quad SPI.FLASH的存储单元无法 ...

  9. ES6学习----let、const、解构赋值、新增字符串、模板字符串、Symbol类型、Proxy、Set

    这篇es6的学习笔记来自于表哥 表严肃,是我遇到过的讲课最通透,英文发音最好听的老师,想一起听课就去这里吧 https://biaoyansu.com/i/hzhj1206 ES6就是JS6,JS的第 ...

  10. 爬虫 -- JS调试

    开发者工具(F12) 其中常用的有Elements(元素面板).Console(控制台面板).Sources(源代码面板).Network(网络面板) 找 JS 文件的几种方法 1.找发起地址 2.设 ...