这是一篇乱七八糟的随笔。
class是ES6新增的特性,用于解决JavaScript没有类的困惑。

--杂谈

ES5及之前,类都是用函数来替代,包括实例。

如:

  1. 1 function Person(name) {
  2. 2 // this指向实例
  3. 3 this.name = name
  4. 4 this,,log = function () {
  5. 5 console.log('name is ' + name)
  6. 6 }
  7. 7 }
  8. 8
  9. 9 // 或者
  10. 10 Person.prototype.changeName = function (name) {
  11. 11 this.name = name
  12. 12 console.log('new name is ' + name)
  13. 13 }
  14. 14
  15. 15 var p = new Person(‘zhangsan’)
  16. 16 p.name // zhangsan
  17. 17 p.log() // name is zhangsan
  18. 18 p.changeName('lisi') // new name is Lisi

class本质上是function的语法糖,不过class的写法更加清晰可见,也更符合面向对象。

由于本质是语法糖,所以偶尔会遇到比如Class转function,function转Class的题目

上面转为class代码如下

  1. 1 class Person {
  2. 2 // constructor是类的构造函数
  3. 3 constructor (name) {
  4. 4 this.name = name
  5. 5 }
  6. 6 log () {
  7. 7 console.log(`name is ${this.name}`)
  8. 8 }
  9. 9 changeName(name) {
  10. 10 this.name = name
  11. 11 console.log(`new name is ${this.name}`)
  12. 12 }
  13. 13 }
  14. 14
  15. 15
  16. 16 var p = new Person('zhangsan'); // 上同

相比函数来声明更加清晰易懂。

class本质也是函数

  1. typeof Person // functionA

类的所有方法都定义在prototype上面

所有上诉的类其实等同于下

  1. Person,prototype = {
  2. log () {...},
  3. changeName(name) {...}
  4. }

类里的内容,除非使用this来表示,则表示内容在实例上,否则都是属于类。

实例在调用方法时候,其实就是调用类上面的原型方法。

  1. p.constructor === Person.prototype.constructor
  1. // p 表示Person的实例
  2. p.hasOwnProperty('name') // true
  3. p.hasOwnProperty('log') // false
  4. p.__proto__.hasOwnProperty('log') // true

类的所有实例共享一个原型对象,所以

  1. p1.__proto__ = p2.__proto__
  1. 还可以通过__proto__来增加类的方法
  1. p.__proto__.printName = function () { return this.name };zha
  1.  

当然这样声明不好,会使得逻辑变得混乱,增加的时候也需要很谨慎,同时不方便管理

-- 其他

class还有许多新的特性,比如支持getter和setter

如:

get 和 set

静态属性,静态方法(只能在类内部使用)

私有属性,通过 #  来声明,如 #count

本来想写许多,想想还是不用记录那么多,主要用于作于记录之用,需要详细还是阅读ES6比较轻松。

一个热爱编程的猴子,感谢与你相遇。

知识就像海洋,搁浅都不一定能见到彼岸。

共勉。

ES6里class杂乱随笔的更多相关文章

  1. 进阶路上有你我-相互相持篇之ES6里箭头函数里的this指向问题

    首先复习下普通函数里的this指向: function test(){ console.log(this) } test() 你会秒杀的毫无疑问的回答:window,针对普通函数:谁调用了函数  函数 ...

  2. es6里class类

    /** * Created by issuser on 2018/11/27. *///如果静态方法包含this关键字,这个this指的是类,而不是实例./** (1)类的实例属性 1.类的实例属性可 ...

  3. ES6里关于类的拓展(一)

    大多数面向对象的编程语言都支持类和类继承的特性,而JS却不支持这些特性,只能通过其他方法定义并关联多个相似的对象,这种状态一直延续到了ES5.由于类似的库层出不穷,最终还是在ECMAScript 6中 ...

  4. ES6里关于作用域的拓展:块级作用域

    过去,javascript缺乏块级作用域,var声明时的声明提升.属性变量等行为让人困惑.ES6的新语法可以帮助我们更好地控制作用域. 一.var声明 1.变量提升:var声明会发生“变量提升”现象, ...

  5. ES6里关于函数的拓展(三)

    一.箭头函数 在ES6中,箭头函数是其中最有趣的新增特性.顾名思义,箭头函数是一种使用箭头(=>)定义函数的新语法,但是它与传统的JS函数有些许不同,主要集中在以下方面: 1.没有this.su ...

  6. ES6里关于函数的拓展(二)

    一.构造函数 Function构造函数是JS语法中很少被用到的一部分,通常我们用它来动态创建新的函数.这种构造函数接受字符串形式的参数,分别为函数参数及函数体 var add = new Functi ...

  7. ES6里关于模板字面量的拓展

    JS 的字符串相对其他语言来说功能总是有限的,事实上,ES5中一直缺乏许多特性,如多行字符串.字符串格式化.HTML转义等.ES6通过模板字面量的方式进行了填补,模板字面量试着跳出JS已有的字符串体系 ...

  8. es6里面的arr方法

    es6里面,关于arr的遍历以及查找,新增了很多的方法,对于不同的应用场景,运用合适的方法,可以达到事半功倍的效果: 一, arr.find():用于查找到符合条件的第一个成员,如果没有查找到的话,则 ...

  9. ES6里新添加了两个很好用的东西,set和Array.from。

    set是一种新的数据结构,它可以接收一个数组或者是类数组对象,自动去重其中的重复项目. 在这我们可以看见,重复的项目已经被去掉了,包括NaN.正常情况下,NaN === NaN 返回的是false,但 ...

随机推荐

  1. 2020年的100天——FLAGS

    2020年的100天--FLAGS Reading <爱的博弈>-- 作者: 约翰·戈特曼 (John Gottman) / 娜恩·西尔弗 (Nan Silver) <人间失格> ...

  2. 破壳漏洞(CVE-2014-6271)分析

    受影响版本:GNU Bash 4.3及之前版本 影响范围:主流的Linux和MacOSX操作系统,与bash交互的各种应用程序,如HTTP,FTP,DHCP等等. 漏洞原理及POC验证: 1.bash ...

  3. PHP:文件包含漏洞

    简单记录一些文件包含漏洞的常用方法 产生原因: 文件包含漏洞的产生原因是在通过引入文件时,由于传入的文件名没有经过合理的校验,或者校检被绕过,从而操作了预想之外的文件,就可能导致意外的文件泄露甚至恶意 ...

  4. SSM框架整合 IDEA_Maven

    首先是配置web的web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app versio ...

  5. Redis深入浅出

    一.基础使用 常用命令 keys,expire(过期),ttl(查看生存时间),set,select,dbsize,flushdb(删除当前库),flushall(删除所有), get,append, ...

  6. python 系统设置

    1. 设置python运行环境为utf-8 import sys #引用sys模块 reload(sys) #重新加载sys sys.setdefaultencoding("utf-8&qu ...

  7. 设计模式PDF下载了4.0万本!那,再肝一本《Java面经手册》吧!

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 1. 先祝贺下自己拿下4.0万本下载量! <重学Java设计模式>PDF ...

  8. Iptables 下 SNAT、DNAT和MASQUERADE三者之间的区别

    Iptables 中可以灵活的做各种网络地址转换(NAT,Network Address Translation) 网络地址转换(NAT)主要有两种:SNAT 和 DNAT,但是也有一种特例 MASQ ...

  9. js获取foreach循环选中的值

    一,循环出来的值,通过checked选中,获取到value值 二,定义一个空数组,用push将数据保存在数组里面 以上操作便可以进行虎丘选中的值了

  10. Java虚拟机系列——检视阅读

    Java虚拟机系列--检视阅读 参考 java虚拟机系列 入门掌握JVM所有知识点 2020重新出发,JAVA高级,JVM JVM基础系列 从 0 开始带你成为JVM实战高手 Java虚拟机-垃圾收集 ...