ES6学习基础
1、let和const
与var不同,新的变量声明方式带来了一些不一样的特性,其中最重要的两个特性就是提供了块级作用域与不再具备变量提升
- {
- let a = 20;
- }
- console.log(a); // a is not defined
当然,代码编译成为了ES5之后,仍然会存在变量提升,因此这一点只需要我们记住即可。在实际使用中,尽量避免使用变量提升的特性带来的负面影响。
使用ES6,我们需要全面使用let/const替换var,什么时候用let,什么时候用const就成为了一个大家要熟练区分的一个知识点。
我们常常使用let来声明一个值会被改变的变量,而使用const来声明一个值不会被改变的变量,也可以称之为常量。
当值为基础数据类型时,那么这里的值,就是指值本身。
而当值对应的为引用数据类型时,那么我这里说的值,则表示指向该对象的引用。这里需要注意,正因为该值为一个引用,只需要保证引用不变就可以,我们仍然可以改变该引用所指向的对象。
当我们试图改变const声明的变量时,则会报错。
- let a = null;
- a = 20;
- const obDev = {
- a: 20,
- b: 30
- }
- obDev.a = 30;
- console.log(obDev); // Object {a: 30, b: 30}
- const fn = function() {}
- const a = obDev.a;
- ... ...
2、箭头函数
ES6颠覆了js的编码习惯,箭头函数的使用占了很大一部分。
首先是写法上的不同:
- // es5
- var fn = function(a, b) {
- return a + b;
- }
- // es6 箭头函数写法,当函数直接被return时,可以省略函数体的括号
- const fn = (a, b) => a + b;
- // es5
- var foo = function() {
- var a = 20;
- var b = 30;
- return a + b;
- }
- // es6
- const foo = () => {
- const a = 20;
- const b = 30;
- return a + b;
- }
需要注意的是,箭头函数可以替换函数表达式,但是不能替换函数声明。
其次还有一点,箭头函数中,没有this。如果在箭头函数中使用了this,那么该this一定就是外层的this。
也正是因为箭头函数中没有this,也就无从谈起用call/apply/bind来改变this指向
- var person = {
- name: 'tom',
- getName: function() {
- return this.name;
- }
- }
- // 如果试图用ES6的写法来重构上面的对象
- const person = {
- name: 'tom',
- getName: () => this.name
- }
- // 编译结果却是
- var person = {
- name: 'tom',
- getName: function getName() {
- return undefined.name;
- }
- };
在ES6中,会默认采用严格模式,因此this也不会自动指向window对象了,而箭头函数本身并没有this,因此this就只能是undefined,如果想用this,就不要用使用箭头函数的写法。
3、模板字符串
模板字符串是为了解决使用+号拼接字符串的不便利而出现的。它的功能很强大,但是使用它则非常简单。举个简单的小例子:
- // es5
- var a = 20;
- var b = 30;
- var string = a + "+" + b + "=" + (a + b);
- // es6
- const a = 20;
- const b = 30;
- const string = `${a}+${b}=${a+b}`;
使用 `` 将整个字符串包裹起来,而在其中使用 ${} 来包裹一个变量或者一个表达式。
4、展开运算符
在ES6中用...
来表示展开运算符,它可以将数组方法或者对象进行展开。
- const arr1 = [1, 2, 3];
- const arr2 = [...arr1, 10, 20, 30];
- // 这样,arr2 就变成了[1, 2, 3, 10, 20, 30];
展开运算符还用在函数的参数中,来表示函数的不定参。只有放在最后才能作为函数的不定参,否则会报错。
- // 所有参数之和
- const add = (a, b, ...more) => {
- return more.reduce((m, n) => m + n) + a + b
- }
- console.log(add(1, 23, 1, 2, 3, 4, 5)) // 39
5、class
ES6为我们创建对象提供了新的语法糖,这就是Class语法。
- // ES5
- // 构造函数
- function Person(name, age) {
- this.name = name;
- this.age = age;
- }
- // 原型方法
- Person.prototype.getName = function() {
- return this.name
- }
- // ES6
- class Person {
- constructor(name, age) { // 构造函数
- this.name = name;
- this.age = age;
- }
- getName() { // 原型方法
- return this.name
- }
- }
ES6学习基础的更多相关文章
- es6常用基础合集
es6常用基础合集 在实际开发中,ES6已经非常普及了.掌握ES6的知识变成了一种必须.尽管我们在使用时仍然需要经过babel编译. ES6彻底改变了前端的编码风格,可以说对于前端的影响非常巨大.值得 ...
- 现代3D图形编程学习-基础简介(2) (译)
本书系列 现代3D图形编程学习 基础简介(2) 图形和渲染 接下去的内容对渲染的过程进行粗略介绍.遇到的部分内容不是很明白也没有关系,在接下去的章节中,会被具体阐述. 你在电脑屏幕上看到的任何东西,包 ...
- 现代3D图形编程学习-基础简介(1) (译)
本书系列 现代3D图形编程学习 基础简介 并不像本书的其他章节,这章内容没有相关的源代码或是项目.本章,我们将讨论向量,图形渲染理论,以及OpenGL. 向量 在阅读这本书的时候,你需要熟悉代数和几何 ...
- JavaScript学习基础部分
JavaScript学习基础 一.简介 1.JavaScript 是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行,比方说 Internet Explorer. Mozilla.Firefo ...
- 【IOS学习基础】NSObject.h学习
一.<NSObject>协议和代理模式 1.在NSObject.h头文件中,我们可以看到 // NSObject类是默认遵守<NSObject>协议的 @interface N ...
- git学习基础教程
分享一个git学习基础教程 http://pan.baidu.com/s/1o6ugkGE 具体在网盘里面的内容..需要的学习可以直接下.
- c语言学习基础:[1]开发工具介绍
标签:c语言 1 2 3 4 分步阅读 学习编程语言的童鞋们一开始接触到的最多的估计就是C语言了,其次才是什么java.c++等,可以说学习c语言是我们走向编程世界的一座桥梁,学好它,对于我们学习和研 ...
- ES6学习目录
前面的话 ES6是JavaScript语言的下一代标准,已经在 2015 年 6 月正式发布.它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言 为什么要学 ...
- 20165318 预备作业二 学习基础和C语言基础调查
20165318 学习基础和C语言基础调查 技能学习经验 我们这一代人,或多或少的都上过各种兴趣班,舞蹈钢琴画画书法,我也是如此.可这些技能中,唯一能拿的出手的就是舞蹈了.按照<优秀的教学方法- ...
随机推荐
- [Angular + TsLint] Disable directive selector tslint error
@Directive({ // tslint:disable-next-line:directive-selector selector: '[scrollable]' })
- Oracle rownum影响运行计划
今天调优一条SQL语句,因为SQL比較复杂,用autotrace非常难一眼看出哪里出了问题,直接上10046. SELECT AB.* FROM (SELECT A.*, rownum RN FROM ...
- hdu 1978 记忆化搜索
注意: dp[i][j] 表示(i,j)这个点有多少种方式 mark[i][j]表示这个点是否走过 假设有直接返回dp[i][j] dp的求法为全部梦走到点的dp的和 注意mark ...
- swift学习笔记(五)构造过程
构造过程是为了使用某个类.结构体或枚举类型的实例而进行的准备过程.在构造过程中,对每一个属性进行了初始值预设和其它必要的准备和初始化工作. 与OC相比,swift的构造函数.不须要返回值.同一时候,在 ...
- hdu4089Activation 概率dp
//一条队列对于第一个人的情况 //概率p1:队列保持不变 //p2:第一个人到队尾 //p3:第一个人出队 //p4:系统崩溃 //队列中有N个人,Tomato 在第M位置,求系统崩溃.Tomato ...
- 【试水CAS-4.0.3】第02节_CAS服务端登录页个性化
完整版见https://jadyer.github.io/2015/07/16/sso-cas-login-diy/ /** * @see ------------------------------ ...
- SharePoint 第一个网站
第一个网站 1.建立一个社区门户网站首先要建一个IIS网站,并且把匿名访问勾选上,这样才能真正的访问网站. 创建网站的时候更改自己想要的端口,以便操作 这里更改网站是否启用匿名访问权限.点击是 然后保 ...
- canvas为什么你指定一个比较小的宽高,但它实际占位却很多?
ccanvas默认的宽高占位是:300*150 px 所以当你画一个普通的举行,你指定的宽高小于默认宽高的时候,通过审查元素发现周围都是空白的.
- AngularJs轻松入门(三)MVC架构
MVC应用程序架构最早于1970年起源于Smalltalk语言,后来在桌面应用程序开发中使用较为广泛,如今在WEB开发中也非常流行.MVC的核心思想是將数据的管理(Model).业务逻辑控制(Cont ...
- springboot整合redis,并解决乱码问题。
热烈推荐:超多IT资源,尽在798资源网 springboot 版本为 1.5.9 //如果是2.x 修改 pom.xml 也可切换成 1.5.9 <parent> <groupId ...