JS在创建之初不支持类,因为很多开发者为处理类创建了好多代码库,最终导致ES6引入了类。

ES5及更早的版本都不支持类,与类最接近的是:创建一个构造器,然后将方法指派到该构造器的原型上。就是原型继承。原型继承的模式在许多JS库中都存在,这也是ES6类的出发点。

类的声明:

以class关键字开始,其后是类的名称;剩余部分的语法看起来像是对象字面量中的方法简写,在方法之间不需要使用逗号。栗子如下:

class personClass{
constructor(name){
this.name = name;
}
sayName(){
console.log(this.name);
}
}
let person = new personClass("Miya");
person.sayName(); //Miya
  console.log(typeof personClass); //function
  console.log(person instanceof personClass); //true
  console.log(typeof personClass.prototype.sayName);  //function
 
  //使用类表达式
  let personClass = class {  ...  }

class中使用特殊的constructor方法名称直接定义一个构造器,之外的方法名称则没有特别的含义,可以根据需求随意添加。

personClass声明实际上创建了一个拥有constructor方法及其行为的函数,typeof personClass会得到“function”结果的原因。sayName()方法最终是personClass.prototype上的一个方法。

为什么要使用类的语法?

类和自定义类型之间的区别:

1,类声明不会被提升,类声明的行为与let相似,因此在程序执行到声明处之前,类都会位于暂时性死区。

2,类声明中的所有代码会自动运行并锁定在严格模式下。

3,类的所有方法不可枚举。

4,类的所有方法内部没有constructor,因此使用new来调用类里面的方法会报错。

5,调用类构造器时不使用new,会报错。

6,试图在类的方法内部重写类名,会报错。

使用类表达式的功能等价于类声明。区别就是代码风格问题,就像:函数声明和函数表达式之间的区别。看下面的定义方法:

let personClass = class personClass2{
constructor(name){
this.name = name;
}
sayName(){
console.log(this.name);
}
}
  console.log(typeof personClass); //function
console.log(typeof personClass2); //undefined

类表达式命名为personClass,personClass2标识符只在类定义内部存在。在类的外部,typeof personClass2的结果为“undefined”,因为在外部不存在personClass2的绑定。其实上面的personClass的定义等价于:

let personClass = (function(){
"use strict";
const personClass2 = function(name){
if(typeof new.target === "undefined"){
throw new Error("Constructor must be called with new");
}
this.name = name;
}
Object.defineProperty(personClass2.prototype,"sayName",{
value:function(){
if(typeof new.target !== "undefined"){
throw new Error("Method cannot ba called with new.");
}
console.log(this.name);
},
enumerable:false,
writable:true,
configurable:true
})
return personClass2;
})

在编程中,能被当作值来使用的就称为一等公民(firstt-class citizen),意味着它能作为参数传给函数,能作为函数返回值,能用来给变量赋值。JS的函数就是一等公民(一等函数)。

ES6的类也是一等公民,使得类可以被多种方式所使用,例如,作为参数传入函数:

function createObject(classDef){
return new classDef();
} let obj = createObject(class {
sayHi(){
console.log("Hi!");
}
})
obj.sayHi(); //Hi!

 类表达式的另一个用途是立即调用类构造器,用于创建单例,看下面栗子;

let person = new class{
constructor(name){
this.name = name;
}
sayName(){
console.log(this.name);
}
}("miya")
console.log(person.sayName()) //miya

 此处创建了一个匿名表达式,并立即执行了它。此模式允许你使用类语法来创建单例,从而不留下任何可被探查的类引用,类表达式后面的圆括号表示要调用前面的函数,并且还允许传入参数。

在类上创建访问器属性(类似于对象字面量):

 自有属性需要在类构造器中创建,类还允许在原型上定义访问器属性。栗子如下:

class htmlEle{
constructor(ele){
this.ele = ele;
}
get html(){
return this.ele.innerHTML;
}
set html(value){
this.ele.innerHTML = value;
}
}
var des = Object.getOwnPropertyDescriptor(htmlEle.prototype, "html");
console.log("get" in des); //true
console.log("set" in des); //true
console.log(des.enumerable); //false

可计算的成员名:

类里面的方法,以及访问器属性getter和setter都可以被设置为可计算属性名。

生成器方法:

对象的类,其实目的在于让每个实例化后的对象都能共享某些属性。类的实现是基于其原型继承机制的。如果两个实例都从同一个原型对象上面继承了属性,我们就说它们是同一个类的实例。
JavaScript中类的一个重要特性-----动态可继承。

定义类是模块开发和重用代码的有效方式之一。一定得掌握的呦!!!

1,类和原型

类的所有实例对象都是从同一个原型对象上继承属性。原型对象是类的核心。

构造函数是类的公共标识。但原型是唯一的标识。

instanceof运算符检测对象的继承关系,而不是检测创建对象的构造函数。

在JavaScript中定义类的步骤:1,定义一个构造函数,设置初始化新对象的实例属性,2,给构造函数的prototype对象定义实例的方法。3,给构造函数定义类字段和类属性。

【续】

人生最要紧,是活得有趣。  ——梁启超

JS的类的更多相关文章

  1. 一个重构的js分页类

    // JavaScript Document /**//** * js分页类 * @param iAbsolute 每页显示记录数 * @param sTableId 分页表格属性ID值,为Strin ...

  2. 分享非常好用的前端分页js工具类 灵活 简单易懂

    分享自己封装的前端分页js工具类  下面是默认样式效果截图 可以随意更改js及css 很灵活 /** * pageSize, 每页显示数 * pageIndex, 当前页数 * pageCount 总 ...

  3. JS常用类

    JS常用类 一.Number 1.常用数字 整数:10 小数:3.14 科学计数法:1e5 | 1e-5 正负无穷:Infinity | -Infinity 2.常用进制 二进制:0b1010 八进制 ...

  4. JS创建类的方法--简单易懂有实例

    版权声明:本文为博主原创文章,转载请注明出处 Javascript是一种基于对象的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有Class. ...

  5. Vue.js的类Class 与属性 Style如何绑定

    Vue.js的类Class 与属性 Style如何绑定 一.总结 一句话总结:数据绑定一个常见需求是操作元素的 class 列表和它的内联样式.因为它们都是属性,我们可以用 v-bind 处理它们:我 ...

  6. js构建类的方法

    Javascript是一种基于对象的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有Class.(不过,ES6引入了Class这个概念,作为对 ...

  7. JS实现 类的 1.判断 2.添加 3.删除 4切换

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. JS定义类的六种方式详解

    转载自: http://www.jb51.net/article/84089.htm 在前端开发中,经常需要定义JS类.那么在JavaScript中,定义类的方式有几种,分别是什么呢?本文就JS定义类 ...

  9. JS 工具类

    之前工作用的JavaScript比较多,总结了一下工具类,和大家分享一下,有不足之处还请多多见谅!! 1. 数组工具类(arrayUtils) var arrayUtils = {}; (functi ...

  10. Rhino+envjs-1.2.js 在java运行网站js 工具类

    java爬虫遇到个页面加密的东西,找了些资料学习学习 做了个java运行js的工具类,希望对大家有用,其中用到client(获取js)可以自行换成自己的client.主要是用了 Rhino就是Java ...

随机推荐

  1. c++与c语言的区别部分

    1.new       <malloc> delete    <free> 2.多态: 重载 <函数     操作符>   类似于c中的变化参数 虚函数 3.模板 ...

  2. 吴裕雄 python 神经网络——TensorFlow 卷积神经网络水果图片识别

    #-*- coding:utf- -*- import time import keras import skimage import numpy as np import tensorflow as ...

  3. python3下scrapy爬虫(第十卷:scrapy数据存储进mysql)

    上一卷中我将爬取的数据文件直接写入文本文件中,现在我将数据存储到mysql中,我依然用的是pymysql,这个很麻烦建表需要在外面建 这次代码只需要改变pipyline就行 来 现在看下结果: 对比发 ...

  4. Java使用JNDI技术获取DataSource对象

    package common; import java.sql.Connection; import java.sql.SQLException; import javax.naming.Contex ...

  5. 【阅读笔记】rocketmq 概念与架构 (一)

    介绍 rocketmq 框架与基本概念 1. 概念 1.1 namesrv(name server) 记录了 broker 集群信息,消息队列的信息以及 key-value 配置,见 RouteInf ...

  6. haproxy笔记之一:Haproxy基本安装配置(反向代理,类似Nginx,可以代理tcp的连接,不只是http)(注意iptables和selinux的问题)

    1.安装haproxy yum -y install haproxy 2.配置文件 # this config needs haproxy- or haproxy- global log 127.0. ...

  7. [hdu4630] No Pain No Game

    某次模拟赛的T1. 刚开始怀疑是RMQ......我真是太弱了QAQ 题目传送门 正解是离线操作,把所有询问按r从小到大排序. 然后把数从左到右处理,处理完第i个数,就可以回答所有r==i的询问了. ...

  8. <USACO07JAN>解决问题Problem Solvingの思路

    日常为dp贡献脑细胞 #include<iostream> #include<cmath> #include<cstdio> #include<cstdlib ...

  9. HTTP接口抓包工具之Fiddler

    Fiddler的基本功能介绍: Fiddler是最强大最好用的Web调试工具之一,它能记录所有客户端和服务器的http和https请求,允许你监视,设置断点,甚至修改输入输出数据,Fiddler包含了 ...

  10. javascript中的function命名空間與模擬getter、setter

    function的命名空間 在javascript中,function也可以擁有自己的命名空間例如以下這段程式碼: 12345678 function () { return 'I am A';} A ...