1.let & const

let:相当于var,不同的是没有变量提升,且只在声明的作用域内有效(新增了块级作用域)。

Const: 声明一个静态场量,一旦声明,常量的值就不能改变。

for..of..遍历

for(let item of arr){}, 需要注意的是如果遍历普通数组时需要返回index值,需要用entries()方法:

for( let [index,item]  of  arr.entries() ){...}

2.String 方法

CodePointAt():  识别字符串,返回十进制码点。

String.fromCharCode():  识别并返回16位的UTF-16字符

String.fromCharPoint():  识别并返回16/32位的UTF-16字符,与CodePointAt()相反

字符串遍历器接口:for..of..(能识别32位的字符,而传统for 循环不能)

Eg: for(let  codePoint  of  “foo”){

Console.Log(codePoint)

}

//”f”

//”o”

//”o”

at():  返回字符串给定位置的字符(能识别32位的字符,而传统charAt()不能)

normalize():  Unicode正规化, 将字符的不同表示方法统一为同样的形式

includes():  返回布尔值,表示是否找到了参数字符串。

startsWith():  返回布尔值,表示参数字符串是否在源字符串的头部。

endsWith():  返回布尔值,表示参数字符串是否在源字符串的尾部。

Repeat():  返回一个新字符串,表示将原字符串重复n次,参数为负时报错,为小数是自动取整,所以0~-0.9为0,NaN为0,

模板字符串:用反引号(`)标示  模板字符串中使用反引号需要用 \ 来转义

在字符串中嵌入变量: `hello ${name}`  // 变量表达式函数调用写在${}中,保留空格与缩进

模板编译:

3.面向对象

3.1      Class(类)类似于java 通过extends实现继承

Class  A{

Constructor(){     //构造函数,this指向实例本身

This.a = “dog”

}

Say(){…}

}

Class  B extends A{

Constructor(){     //构造函数,this指向实例本身

//super继承父类的this对象,子类必须在constructor方法中调用super方法,否则新建实例时会报错。这是因为子类没有自己的this对象

super()

This.a = “cat”

}

}

ES6的继承机制,实质是先创造父类的实例对象this(所以必须先调用super方法),然后再用子类的构造函数修改this。

React中用的很多,创建的每个component都是一个继承React.Component的类

4.Arrow function

Class  A{

Constructor(){

This.a = “cat”

}

Say(){

//如果不用箭头函数,settimeout中的this本应该绑在全局变量

setTimeout( () => {

console.log(this.a)

}, 1000)

}

}

自带this,函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象,可以解决很多this指向带来的问题。

实际原因是箭头函数根本没有自己的this,它的this是继承外面的,因此内部的this就是外层代码块的this。

5.Destructuring(解构)

let cat = 'ken'

let dog = 'lili'

let zoo = {cat: cat, dog: dog} //ES5

let zoo = {cat, dog}  //ES6

反过来可以这么写:

let dog = {type: 'animal', many: 2}

let { type, many} = dog

console.log(type, many)

  1. Default  rest

function animal(type = 'cat'){

   console.log(type)

}

animal(); //cat

rest:

function animals(...types){

   console.log(types)

}

animals('cat', 'dog', 'fish') //["cat", "dog", "fish"]

交换变量的值: [x , y] = [y , x]

6.import export(es6 module功能)

传统的写法

首先我们回顾下require.js的写法。假设我们有两个js文件: index.js和content.js,现在我们想要在index.js中使用content.js返回的结果,我们要怎么做呢?

首先定义:

//content.js

define('content.js', function(){

   return 'A cat';

})

然后require:

//index.js

require(['./content.js'], function(animal){

   console.log(animal);   //A cat

})

那CommonJS是怎么写的呢?

//index.js

var animal = require('./content.js')

 

//content.js

module.exports = 'A cat'

ES6的写法

//index.js

import animal from './content'

 

//content.js

export default 'A cat'

export命令除了输出变量,还可以输出函数,甚至是类(有没有很眼熟 react的模块基本都是输出类)

ES6 小记的更多相关文章

  1. es6小记

    let, const, class, extends, super, arrow functions, template string, destructuring, default, rest ar ...

  2. Angular2 初学小记

    1.与Angular1的异同 几乎完全不同(什么鬼~ 1)保留一些特性 表达式仍旧用{{}}. 2)属性指令变为驼峰式 ng-if ---> ngIf 3)ng-repeat被ngFor代替 4 ...

  3. 随手小记(es6)

    在学习前辈阮一峰大神写的<ECMAScript入门>一书的过程中,第九章中讲到对象扩展时,第一条我就有点看不懂 ES6允许直接写入变量和函数,作为对象的属性和方法.这样的书写更加简洁. v ...

  4. es6 学习小记 扩展运算符 三个点(...)

    参考: es6 扩展运算符 三个点(...) 经常回顾,方能真正掌握. 一.含义 扩展运算符( spread )是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. ...

  5. 前端小记6——项目中常用的ES6方法

    现在很多功能用es5的方法也能实现功能,但es6提供的方法显得更为高效.记录下目前常用的几个方法. 1.字符包含 通过str.includes('a')来判断, 若str中包含a则结果为true,否则 ...

  6. ES6——>let,箭头函数,this指向小记

    let let允许你声明一个作用域被限制在块级中的变量.语句或者表达式. 还是那个经典的问题:创建5个li,点击不同的li能够打印出当前li的序号. 如果在for循环中使用**var**来声明变量i的 ...

  7. ES6模块import细节

    写在前面,目前浏览器对ES6的import支持还不是很好,需要用bable转译. ES6引入外部模块分两种情况: 1.导入外部的变量或函数等: import {firstName, lastName, ...

  8. webpack+react+redux+es6开发模式

    一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...

  9. ES6的一些常用特性

    由于公司的前端业务全部基于ES6开发,于是给自己开个小灶补补ES6的一些常用特性.原来打算花两天学习ES6的,结果花了3天才勉强过了一遍阮老师的ES6标准入门(水好深,ES6没学好ES7又来了...) ...

随机推荐

  1. 《C++primerplus》第8章练习题

    1.(简单用一下引用变量,没有采用书中的题目)定义一个替身结构体,存储名字(char[])和力量值(int).使用结构体引用作为形参写两个函数,一个不加const,使得能对定义的结构体做修改,另一个加 ...

  2. Combine 框架,从0到1 —— 5.Combine 常用操作符

    本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 常用操作符. 内容概览 前言 print breakpoint handleEve ...

  3. 基于Intel x86 Android的RAD游戏开发

    zip文件还包含编译的"MonkeyGame-debug".可以在模拟器中运行的二进制文件.在"game.build"文件夹中有一个HTML5 build.在C ...

  4. Mock测试你的Spring MVC接口

    1. 前言 在Java开发中接触的开发者大多数不太注重对接口的测试,结果在联调对接中出现各种问题.也有的使用Postman等工具进行测试,虽然在使用上没有什么问题,如果接口增加了权限测试起来就比较恶心 ...

  5. MeteoInfoLab脚本示例:AVHRR HDF数据

    这里演示读取和绘制AVHRR hdf格式数据,以sst(海表面温度)为例. 脚本程序: #Add data file f = addfile('D:/Temp/hdf/2006001-2006005. ...

  6. MeteoInfoLab脚本示例:线性拟合

    MeteoInfoLab提供一个线性拟合函数linregress,参数是参与拟合的两个数据序列,返回拟合的斜率.截距和相关系数.有了上述拟合参数可以用polyval函数生成拟合数据(直线).然后可以将 ...

  7. 安装Node,创建vue项目,运行及打包

    1.安装node js 下载地址:http://nodejs.cn/download/ 2.安装完成后运行Node.js command prompt(node -v查看安装版本) 3.安装npm(由 ...

  8. 加密sqlite3数据库文件

    目录 EncryptSqlite3 实现原理 使用方法 不足之处 GitHub地址 EncryptSqlite3 加密sqlite3数据库,产生的数据库文件别人打不开. 实现原理 在写入文件前对每个字 ...

  9. 【贪心算法】HDU 5747 Aaronson

    题目大意 vjudge链接 给你一个n,m,求解满足等式x0+2x1+4x2+...+2mxm=n的x0~xm的最小和(xi为非负整数) 数据范围 0≤n,m≤109 思路 n和m都在int范围内,所 ...

  10. Ubuntu服务安装

    一.ifconfig命令安装 sudo apt install net-tools 二.ssh服务安装 sudo apt-get install openssh-server netstat -ltn ...