1、let和const

与var不同,新的变量声明方式带来了一些不一样的特性,其中最重要的两个特性就是提供了块级作用域与不再具备变量提升

  1. {
  2. let a = 20;
  3. }
  4.  
  5. console.log(a); // a is not defined

当然,代码编译成为了ES5之后,仍然会存在变量提升,因此这一点只需要我们记住即可。在实际使用中,尽量避免使用变量提升的特性带来的负面影响。

使用ES6,我们需要全面使用let/const替换var,什么时候用let,什么时候用const就成为了一个大家要熟练区分的一个知识点。

我们常常使用let来声明一个值会被改变的变量,而使用const来声明一个值不会被改变的变量,也可以称之为常量。

当值为基础数据类型时,那么这里的值,就是指值本身。
而当值对应的为引用数据类型时,那么我这里说的值,则表示指向该对象的引用。这里需要注意,正因为该值为一个引用,只需要保证引用不变就可以,我们仍然可以改变该引用所指向的对象。

当我们试图改变const声明的变量时,则会报错。

  1. let a = null;
  2. a = 20;
  3. const obDev = {
  4. a: 20,
  5. b: 30
  6. }
  7.  
  8. obDev.a = 30;
  9.  
  10. console.log(obDev); // Object {a: 30, b: 30}
  11. const fn = function() {}
  12. const a = obDev.a;
  13. ... ...

2、箭头函数

ES6颠覆了js的编码习惯,箭头函数的使用占了很大一部分。

首先是写法上的不同:

  1. // es5
  2. var fn = function(a, b) {
  3. return a + b;
  4. }
  5.  
  6. // es6 箭头函数写法,当函数直接被return时,可以省略函数体的括号
  7. const fn = (a, b) => a + b;
  8.  
  9. // es5
  10. var foo = function() {
  11. var a = 20
  12. var b = 30;
  13. return a + b;
  14. }
  15.  
  16. // es6
  17. const foo = () => {
  18. const a = 20;
  19. const b = 30;
  20. return a + b;
  21. }

需要注意的是,箭头函数可以替换函数表达式,但是不能替换函数声明。

其次还有一点,箭头函数中,没有this。如果在箭头函数中使用了this,那么该this一定就是外层的this。

也正是因为箭头函数中没有this,也就无从谈起用call/apply/bind来改变this指向

  1. var person = {
  2. name: 'tom',
  3. getName: function() {
  4. return this.name;
  5. }
  6. }
  7.  
  8. // 如果试图用ES6的写法来重构上面的对象
  9. const person = {
  10. name: 'tom',
  11. getName: () => this.name
  12. }
  13.  
  14. // 编译结果却是
  15. var person = {
  16. name: 'tom',
  17. getName: function getName() {
  18. return undefined.name;
  19. }
  20. };

在ES6中,会默认采用严格模式,因此this也不会自动指向window对象了,而箭头函数本身并没有this,因此this就只能是undefined,如果想用this,就不要用使用箭头函数的写法。

3、模板字符串

模板字符串是为了解决使用+号拼接字符串的不便利而出现的。它的功能很强大,但是使用它则非常简单。举个简单的小例子:

  1. // es5
  2. var a = 20;
  3. var b = 30;
  4. var string = a + "+" + b + "=" + (a + b);
  5.  
  6. // es6
  7. const a = 20;
  8. const b = 30;
  9. const string = `${a}+${b}=${a+b}`;

使用 `` 将整个字符串包裹起来,而在其中使用 ${} 来包裹一个变量或者一个表达式。

4、展开运算符

在ES6中用...来表示展开运算符,它可以将数组方法或者对象进行展开。

  1. const arr1 = [1, 2, 3];
  2. const arr2 = [...arr1, 10, 20, 30];
  3.  
  4. // 这样,arr2 就变成了[1, 2, 3, 10, 20, 30];

展开运算符还用在函数的参数中,来表示函数的不定参。只有放在最后才能作为函数的不定参,否则会报错。

  1. // 所有参数之和
  2. const add = (a, b, ...more) => {
  3. return more.reduce((m, n) => m + n) + a + b
  4. }
  5.  
  6. console.log(add(1, 23, 1, 2, 3, 4, 5)) // 39

5、class

ES6为我们创建对象提供了新的语法糖,这就是Class语法。

  1. // ES5
  2. // 构造函数
  3. function Person(name, age) {
  4. this.name = name;
  5. this.age = age;
  6. }
  7.  
  8. // 原型方法
  9. Person.prototype.getName = function() {
  10. return this.name
  11. }
  12.  
  13. // ES6
  14. class Person {
  15. constructor(name, age) { // 构造函数
  16. this.name = name;
  17. this.age = age;
  18. }
  19.  
  20. getName() { // 原型方法
  21. return this.name
  22. }
  23. }

ES6学习基础的更多相关文章

  1. es6常用基础合集

    es6常用基础合集 在实际开发中,ES6已经非常普及了.掌握ES6的知识变成了一种必须.尽管我们在使用时仍然需要经过babel编译. ES6彻底改变了前端的编码风格,可以说对于前端的影响非常巨大.值得 ...

  2. 现代3D图形编程学习-基础简介(2) (译)

    本书系列 现代3D图形编程学习 基础简介(2) 图形和渲染 接下去的内容对渲染的过程进行粗略介绍.遇到的部分内容不是很明白也没有关系,在接下去的章节中,会被具体阐述. 你在电脑屏幕上看到的任何东西,包 ...

  3. 现代3D图形编程学习-基础简介(1) (译)

    本书系列 现代3D图形编程学习 基础简介 并不像本书的其他章节,这章内容没有相关的源代码或是项目.本章,我们将讨论向量,图形渲染理论,以及OpenGL. 向量 在阅读这本书的时候,你需要熟悉代数和几何 ...

  4. JavaScript学习基础部分

    JavaScript学习基础 一.简介 1.JavaScript 是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行,比方说 Internet Explorer. Mozilla.Firefo ...

  5. 【IOS学习基础】NSObject.h学习

    一.<NSObject>协议和代理模式 1.在NSObject.h头文件中,我们可以看到 // NSObject类是默认遵守<NSObject>协议的 @interface N ...

  6. git学习基础教程

    分享一个git学习基础教程 http://pan.baidu.com/s/1o6ugkGE 具体在网盘里面的内容..需要的学习可以直接下.

  7. c语言学习基础:[1]开发工具介绍

    标签:c语言 1 2 3 4 分步阅读 学习编程语言的童鞋们一开始接触到的最多的估计就是C语言了,其次才是什么java.c++等,可以说学习c语言是我们走向编程世界的一座桥梁,学好它,对于我们学习和研 ...

  8. ES6学习目录

    前面的话 ES6是JavaScript语言的下一代标准,已经在 2015 年 6 月正式发布.它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言 为什么要学 ...

  9. 20165318 预备作业二 学习基础和C语言基础调查

    20165318 学习基础和C语言基础调查 技能学习经验 我们这一代人,或多或少的都上过各种兴趣班,舞蹈钢琴画画书法,我也是如此.可这些技能中,唯一能拿的出手的就是舞蹈了.按照<优秀的教学方法- ...

随机推荐

  1. [Angular + TsLint] Disable directive selector tslint error

    @Directive({ // tslint:disable-next-line:directive-selector selector: '[scrollable]' })

  2. Oracle rownum影响运行计划

    今天调优一条SQL语句,因为SQL比較复杂,用autotrace非常难一眼看出哪里出了问题,直接上10046. SELECT AB.* FROM (SELECT A.*, rownum RN FROM ...

  3. hdu 1978 记忆化搜索

    注意: dp[i][j] 表示(i,j)这个点有多少种方式       mark[i][j]表示这个点是否走过  假设有直接返回dp[i][j]    dp的求法为全部梦走到点的dp的和 注意mark ...

  4. swift学习笔记(五)构造过程

    构造过程是为了使用某个类.结构体或枚举类型的实例而进行的准备过程.在构造过程中,对每一个属性进行了初始值预设和其它必要的准备和初始化工作. 与OC相比,swift的构造函数.不须要返回值.同一时候,在 ...

  5. hdu4089Activation 概率dp

    //一条队列对于第一个人的情况 //概率p1:队列保持不变 //p2:第一个人到队尾 //p3:第一个人出队 //p4:系统崩溃 //队列中有N个人,Tomato 在第M位置,求系统崩溃.Tomato ...

  6. 【试水CAS-4.0.3】第02节_CAS服务端登录页个性化

    完整版见https://jadyer.github.io/2015/07/16/sso-cas-login-diy/ /** * @see ------------------------------ ...

  7. SharePoint 第一个网站

    第一个网站 1.建立一个社区门户网站首先要建一个IIS网站,并且把匿名访问勾选上,这样才能真正的访问网站. 创建网站的时候更改自己想要的端口,以便操作 这里更改网站是否启用匿名访问权限.点击是 然后保 ...

  8. canvas为什么你指定一个比较小的宽高,但它实际占位却很多?

    ccanvas默认的宽高占位是:300*150  px  所以当你画一个普通的举行,你指定的宽高小于默认宽高的时候,通过审查元素发现周围都是空白的.

  9. AngularJs轻松入门(三)MVC架构

    MVC应用程序架构最早于1970年起源于Smalltalk语言,后来在桌面应用程序开发中使用较为广泛,如今在WEB开发中也非常流行.MVC的核心思想是將数据的管理(Model).业务逻辑控制(Cont ...

  10. springboot整合redis,并解决乱码问题。

    热烈推荐:超多IT资源,尽在798资源网 springboot 版本为 1.5.9 //如果是2.x 修改 pom.xml 也可切换成 1.5.9 <parent> <groupId ...