es6

支持情况

  1. nodejs几乎完全支持es6的语法
  2. chrome下可以使用小部分的es6, 需要使用严格模式, 'use strict';
  3. firefox下使用需要知道测试版本,需要在script标签加上type属性
<script type="application/javascript;version=1.7"></script>
  1. let 声明变量

与var的区别:

  1. var可以重复声明,let不能重复声明
var a;
var a;

let b;
let b;//报错
  1. var声明的变量会声明提前,let不会
console.log(a);//undefined
var a=3;
console.log(a);//报错
let a=3;
  1. var声明的变量时函数作用域,let是块级作用域
{
    let a=1;
    console.log(1);//1
}
console.log(a);//报错

一个例子:

for(let i=0;i<10;i++){
    setTimeout(function(){
        console.log(i);
    })
}

const

常量, 值不能修改

"use strict";
const a=1;
a=2;//报错

如果常量保存的是一个对象, 那对象是可以被修改的

"use strict";
const a={
    b: 1,
};
a.b=2;

解构赋值(destructuring)

ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值

数组的解构赋值

按照对应的顺序解构

var arr=[1,2,3];
var [a,b,c]= arr;
console.log(a,b,c);
var arr=[1,[2,3]];
var [a,[b,c]]= arr;
console.log(a,b,c);
对象的解构赋值

跟顺序无关, 是根据键名和变量名对应来的

var obj = {
    foo: function(){

        },
        o: {},
        arr: [],
        str: 'abc'
}
var { foo, arr, str } = obj;
console.log(foo, arr, str);
作用
  1. 返回对象或数组方便取值
function fn(){
    return { x: 1, y: 1};
}

var {x, y} =  fn();
  1. 值的交换
var x=1;
var y=2;
var [x,y] = [y, x];

字符串的扩展

str.codePointAt()

js内部,字符以UTF-16的格式存储,每个字符固定为2个字节。
对于那些需要以4个字节存储的字符(unicode编码大于0xFFFF的字符),
js会认为它们是两个字符。

var a='字';
console.log(a.length);//1
a='𠮷';

console.log(a.length);//2

所以, 我们使用str.charCodeAt,没有办法正确的得到它的编码值

var a='𠮷';

a.charCodeAt(0);//55362 前两个字节
a.charCodeAt(1);//57271 后两个字节

可以用str.codePointAt

a.codePointAt(0);//134071
String.fromCodePoint(134071);//𠮷
a.at(0);//𠮷

codePointAt fromCodePoint at三个方法是可以操作4个字节的字符

模板字符串

用反引号(`)标识, 它可以当作普通字符串使用,也可以用来定义多行字符串,或在字符串中嵌入变量。

var name = 'xx';
var age = '19';

var str = `你的名字: ${name}, 你的年龄${age}`;//注意:这里是反引号,不是引号

字符串的unicode标识法

之前, js允许采用'\uXXXX'的形式表示一个字符,其中'XXXX'表示字符的码点(unicode编码的值)

但是,只限于\u0000---\uFFFF之间的字符。超出范围的字符,必须用两个字节的形式表达。

'\uD843\uDFB7';//𠮷

es6做出了改进: 只要将码点放入大括号中

'\u{20BB7}';//𠮷
'\u{41}\u{42}\u{43}';//ABC

其他方法

str.includes
str.startWith
str.endWith

数值的扩展

二进制和八进制新的写法

var a = 0b11;//3
var b = 0o11;//9

Math的扩展

Math.trunc

去除小数部分,保留整数部分,和parseInt的结果差不多

Math.sign

判断是整数还是负数,主要是判断-0这种情况
正数返回1, 负数返回-1;
0返回0, -0返回-0;

Math.sign(5);//1
Math.sign(-5);//-1
Math.sign(0);//0
Math.sign(-0);//-0

数组的扩展

Array.from

作用:将一个类数组转成数组

var aLi = document.getElementsByTagName('li');
var arrLi = Array.from(aLi);

//等同于
[].slice.call(aLi);

Array.of

把参数变成数组

var arr = Array.of(1,2,3);//[1,2,3]

arr.find

找出第一符合条件的数组元素

参数:

  1. 回调函数
  2. 回调函数this的指向

遍历数组,遍历过程中调用回调函数,如果返回值为true,返回当前遍历的数组元素

如果都为false,返回undefined

var arr = [1,2,3,4,5];
var obj = {
    n:3
}
var n = arr.find(function(val, i, arr){
    if(this.n===val){
        return true;
    }
}, obj)

arr.findIndex

找出第一个符合条件的数组元素的位置

参数:

  1. 回调函数
  2. 回调函数this的指向

遍历数组,遍历过程中调用回调函数,如果返回值为true,返回当前遍历的数组元素的索引

如果都为false,返回-1

arr.fill

填充数组

参数:

  1. 填充的内容
  2. 起始位置
  3. 结束位置
var arr = [1,2,3,4,5];
arr.fill(6);//[6, 6, 6, 6, 6]
arr;//[6, 6, 6, 6, 6]
var arr = [1,2,3,4,5];
arr.fill(6, 3);//[1, 2, 3, 6, 6]
var arr = [1,2,3,4,5];
//不包含结束位置
arr.fill(6, 3, 4);//[1, 2, 3, 6, 5]

使用场景: 小游戏中的矩阵,往其中写数据, 以前都是用的for循环,现在可以使用fill

for of

for( let value of []){}

for of用来遍历拥有遍历接口的对象的属性值
( 数组,字符串有遍历接口,{}没有遍历接口 )

var arr = [1,2,3,4,5];
for(var val of arr){
    console.log(val);
}

for(var val of arr.values()){
    console.log(val);
}

for(var key of arr.keys()){
    console.log(key);
}

for(var [key, val] of arr.entries() ){
    console.log(key, val);
}

数组推导

var arr = [1,2,3,4];

var newArr = [ for(val of arr) val*2 ];

对象的扩展

对象的简写

属性的简写

var x=1;
var y=1;

//直接写变量名
var obj = {x,y};//{x:1, y:1};

方法的简写:

var obj = {
    fn(){
        return 'fn';
    }
}

属性名表达式

es6允许字面量定义对象时,用表达式作为对象的属性名,
即把表达式放在括号内,属性名为表达式计算之后的值

var obj = {
    ['a'+'b']: 1
};
//{ab: 1};

Object.is

判断传入的参数是否相等

0===-0;//true
NaN === NaN; //false
Object.is(0, -0);//false
Object.is(NaN, NaN); //true

Object.assign

功能和$.extend类似

var obj1 = {};
var obj2 = { name: 'xxx' };
var obj3 = { name: 'yyy', age: 34};

Object(obj1, obj2, obj3);
obj1;//{ name: 'yyy', age: 34}

Object.getPrototypeOf(obj)

用来获取一个对象的prototype对象

function Cat(name){
    this.name = name;
}

Cat.prototype.getName = function(){
    return this.name;
}


var cat = new Cat('xxxx');

console.log( Object.getPrototypeOf(cat) === Cat.prototype );//true

Object.setPrototypeOf(obj, prototype)

用来设置一个对象的prototype对象

function Cat(name){
    this.name = name;
}

Cat.prototype.getName = function(){
    return this.name;
}


var cat = new Cat('xxxx');
Object.setPrototypeOf(cat, {});

console.log( Object.getPrototypeOf(cat) );//{}

也可以使用__proto__

__proto__

用来读取和设置当前对象的prototype

Proxy

var obj = {
    a: 1
}

var p = new Proxy(obj, {
    get: function(obj, attr){//获取值的时候调用
        console.log('get attr');
        return obj[attr];
    },
    set: function(obj, attr, value){//设置值的时候调用
        console.log('set attr');
        obj[attr] = value;
        return true;
    }
})

p.a = 2;
p.a;

get set必须都要写

Object.observe(obj, observe, [eventType])

用于监测对象的变化,一旦发生变化就会调用回调函数

参数:

  1. 需要监控的对象
  2. 回调函数(回调函数接受一个数组参数 修改历史 )
  3. 指定事件

eventType:

  • add: 添加属性
  • update: 属性值的变化
  • delete:删除属性
  • setPrototype: 设置原型
  • reconfigure: 属性的attributes对象发生变化

Object.unobserve(obj, fn)

函数扩展

参数默认值

function fn(a, b, c=2){

}

function fn(a, b, ...rest){
    //获取函数的多余参数, 是一个数组
    console.log(rest);
}

扩展运算符


function fn(a,b,c){
    console.log(a, b, c);
}
var arr = [1, 2, 3];
fn(...arr);

将字符串变成一个数组

var str = 'abc';
var arr = [...str];
console.log(arr);

扩展运算符...是将数组,字符串这些有遍历接口的变成a,b,c这样以逗号分开的参数列表

箭头函数

主要作用:用来作为回调函数使用

var arr = [];
arr.sort( (a,b)=>{
    a-b
} )

注意:

  1. 函数体内的this对象,绑定定义时所在的对象,而不是使用时所在的对象
  2. 不可以当作构造函数,不可以使用new命令
  3. 该函数体内不存在arguments
function foo() {
  setTimeout(() => {
    console.log('id:', this.id);
  }, 100);
}

var id = 21;

foo.call({ id: 42 });
// id: 42
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容

  • [TOC] 参考阮一峰的ECMAScript 6 入门参考深入浅出ES6 let和const let和const都...
    郭子web阅读 1,773评论 0 1
  • 三,字符串扩展 3.1 Unicode表示法 ES6 做出了改进,只要将码点放入大括号,就能正确解读该字符。有了这...
    eastbaby阅读 1,521评论 0 8
  • 一、ES6简介 ​ 历时将近6年的时间来制定的新 ECMAScript 标准 ECMAScript 6(亦称 ...
    一岁一枯荣_阅读 6,065评论 8 25
  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    呼呼哥阅读 3,364评论 0 1
  • 泉州轻工职业学院位于著名侨乡、中国品牌之都——泉州晋江市,由福建省人民政府批准成立,教育部核准纳入全国高考统一招生...
    homebbbb阅读 337评论 0 0