ES6新增语法

(一)let和const

1.let

  • let 定义变量,变量不可以再次定义,但可以改变其值

代码举栗:

let name = 'zhangsan';
name = 'lisi';
console.log(name); // lisi
let name = 'wangwu'; // 再次定义,报错:Identifier 'name' has already been declared
  • 具有块级作用域。(即大括号)

代码举栗:

{
    let age = 18;
    console.log(age); // 18
}
console.log(age); // 报错,此作用域中没有age的定义

for (let i = 0; i < 10; i++) {
    // i 只能在此范围内使用,因为有块级作用域
}
console.log(i);  // 报错,此作用域中没有i的定义
  • 没有变量提升,必须先定义再使用

代码举栗:

console.log(gender); // 报错,此时还没有定义gender
let gender = '男'; 
  • let声明的变量不会压到window对象中,是独立的

代码举栗:

let hobby = '吃饭';
console.log(window.hobby); // undefined

如果使用var声明了变量,也不能再次用let声明了,反之也是不行的。原因也是这个变量已经被声明过了。

2.const

  • 使用const关键字定义常量
  • 常量是不可变的,一旦定义,则不能修改其值

代码举栗:

// 1. 使用const关键字定义常量,常量名一般大写
// 2. 常量是不可变的,一旦定义,则不能修改其值
const PI = 3.1415926;
PI = 3.14; // 报错,常用一旦被初始化,则不能被修改
  • 初始化常量时,必须给初始值

代码举栗:

const PI; 
// 报错,Missing initializer in const declaration
  • 具有块级作用域
  • 没有变量提升,必须先定义再使用
  • 常量也是独立的,定义后不会压入到window对象中

3.总结

image.png

(二)解构赋值

1.数组解构

// 情况1,变量和值一一对应
let arr = [5, 9, 10];
let [a, b, c] = arr;
console.log(a, b, c); // 输出 5 9 10

// 情况2,变量多,值少
let arr = [5, 9, 10];
let [a, b, c, d] = arr;
console.log(a, b, c, d); // 输出 5 9 10 undefined

// 情况3,变量少,值多
let arr = [5, 9, 10, 8, 3, 2];
let [a, b] = arr;
console.log(a, b); // 5, 9

// 情况4,按需取值
let arr = [5, 9, 10, 8, 3, 2];
let [, , a, , b] = arr; // 不需要用变量接收的值,用空位占位
console.log(a, b); // 10, 3 

// 情况5,剩余值
let arr = [5, 9, 10, 8, 3, 2];
let [a, b, ...c] = arr; // ...c 接收剩余的其他值,得到的c是一个数组
console.log(a, b, c); 
// 结果:
// a = 5, 
// b = 9, 
// c = [10, 8, 3, 2]

// 情况6,复杂的情况,只要符合模式,即可解构
let arr = ['zhangsan', 18, ['175cm', '65kg']];
let [, , [a, b]] = arr;
console.log(a, b); // 175cm 65kg

2.对象解构

// 情况1,默认要求变量名和属性名一样
let { foo, bar } = {foo: 'aaa', bar: 'bbb'};
console.log(foo, bar); // aaa, bbb
let {a, c} = {a: 'hello', b: 'world'};
console.log(a, c); // hello, undefined

// 情况2,可以通过:为变量改名
let {a, b:c} = {a: 'hello', b: 'world'};
console.log(a, c); // hello, world

// 情况3,变量名和属性名一致即可获取到值,不一定要一一对应
let {b} = {a: 'hello', b: 'world'};
console.log(b); // world
// 此时,没有定义变量a,所以使用a会报错

// 情况4,剩余值
let obj = {name:'zs', age:20, gender:'男'};
let {name, ...a} = obj;
console.log(name, a);
// 结果:
// name = zs
// a = {age: 20, gender: "男"};

// 情况5,复杂的情况,只要符合模式,即可解构
let obj = {
    name: 'zhangsan',
    age: 22,
    dog: {
        name: '毛毛',
        age: 3
    }
};
let {dog: {name, age}} = obj;
console.log(name, age); // 毛毛 3

(三)函数和参数

1.箭头函数

使用箭头定义函数 => goes to,目的是简化函数的定义并且里面的this也比较特殊。

基本定义:

// 非箭头函数
let fn = function (x) {
    return x * 2;
}
// 箭头函数,等同于上面的函数
let fn = (x) => {
    return x * 2;
}
  • 形参只有一个可以省略小括号
let fn = (x) => {
    return x * 2;
}
// 等同于
let fn = x => {
    return x * 2;
}
  • 函数体只有一句话,可以省略大括号,并且表示返回函数体的内容
let fn = (x, y) => {
    return x + y;
}
// 等同于
let fn = (x, y) => x + y;
  • 箭头函数内部没有 arguments
let fn = () => {
    console.log(arguments); // 报错,arguments is not defined
};
  • 箭头函数内部的 this 指向外部作用域中的 this ,或者可以认为箭头函数没有自己的 this
 // 这里必须用var,因为用let声明的变量不能使用window调用
    var name = 'lisi';
    let obj = {
        name: 'zhangsan',
        fn: () => {
            console.log(this); // window对象
            console.log(this.name); // lisi
        }
    };
    obj.fn();
  • 箭头函数不能作为构造函数
let Person = () => {
    
};
let obj = new Person(); // 报错,Person is not a constructor
// 箭头函数中都没有自己的this,不能处理成员,所以不能当构造函数

2.参数的默认值

ES6中可以给函数的参数设置默认值

function fn(x, y = 'world') {
    console.log(x, y);
}
fn(2)
fn(2,3)
//打印结果
//2 “world”
//2 3

3.rest参数

剩余参数,以 修饰最后一个参数,把多余的参数都放到一个数组中。可以替代 arguments 的使用。
rest 参数只能是最后一个参数。

代码举栗:

// 参数很多,不确定多少个,可以使用剩余参数
function fn(...values) {
    console.log(values); // [6, 1, 100, 9, 10]
}
// 调用
console.log(fn(6, 1, 100, 9, 10)); //undefined
function fn(a, b, ...values) {
    console.log(a); // 6
    console.log(b); // 1
    console.log(values); // [100, 9, 10]
}
// 调用
console.log(fn(6, 1, 100, 9, 10)); //undefined

(四)内置函数的扩展

1.扩展运算符:...

...可以把数组中的每一项展开

代码举栗:

// 合并两个数组
let arr1 = [1, 2];
let arr2 = [3, 4];
let arr3 = [...arr1, ...arr2];
console.log(arr3); // [1, 2, 3, 4]
// 把数组展开作为参数,可以替代 apply
// 求数组的最大值
let arr = [6, 99, 10, 1];
let max = Math.max(...arr); // 等同于 Math.max(6, 99, 10, 1);

2.Array.from()

把伪数组转成数组

  • 伪数组必须有length属性,如果没有将返回一个空数组
  • 转换后的数组长度,是根据伪数组的length决定的

代码举栗:

let fakeArr = {
  0: 'a',
  1: 'b',
  2: 'c',
  length: 3
};
let arr = Array.from(fakeArr);
console.log(arr); // ['a', 'b', 'c']
// 转数组的对象必须有length值,因为得到的数组的成员个数是length指定的个数
// 上例中,如果length为2,则得到的数组为 ['a', 'b']

3.find()方法和findIndex()方法

find():用于查找数组中的值
findIndex():用于查找数组的下标,用法与find一样

代码举栗:

    let value = [3, 5, -1, -4, 6].find((item, index, arr) => {
        console.log(item); //表示数组的每个值
        console.log(index); //表示数组的每个下标
        console.log(arr); //表示整个数组
        //如果需要查找,要用到return 条件;
        return item < 0; //find方法会返回第一个满足条件的值,-1
        //如果是findIndex方法,会返回第一个满足条件的值的下标,2
    });
    console.log(value);
  • find 找到数组中第一个满足条件的成员并返回该成员,如果找不到返回undefined
  • findIndex 找到数组中第一个满足条件的成员并返回该成员的索引,如果找不到返回 -1

4.includes()方法

  • 判断数组是否包含某个值,返回 true / false
  • 参数1,必须,表示查找的内容
  • 参数2,可选,表示开始查找的位置,0表示开头的位置

代码举栗:

let arr = [1, 4, 3, 9];
console.log(arr.includes(4)); // true
console.log(arr.includes(4, 2)); // false, 从2的位置开始查,所以没有找到4
console.log(arr.includes(5)); // false

5.includes(), startsWith(), endsWith()

  • includes(str, [position]) 返回布尔值,表示是否找到了参数字符串
  • startsWidth(str, [position]) 返回布尔值,表示参数字符串是否在原字符串的头部或指定位置
  • endsWith(str, [position]) 返回布尔值,表示参数字符串是否在原字符串的尾部或指定位置。
console.log('hello world'.includes('e', 2)); // false 从位置2开始查找e,没有找到
console.log('hello world'.includes('e')); // true
console.log('hello world'.startsWith('h')); // 未指定位置,看开头是否是h,返回true
console.log('hello world'.startsWith('l', 2)); // 指定位置的字符是l,返回true
console.log('hello world'.endsWith('d')); // 未指定位置,结尾是d,返回true
console.log('hello world'.endsWith('r', 9)); // 指定位置的字符是r,返回true

6.repeat()方法

repeat方法返回一个新字符串,表示将原字符串重复n次。

let html = '<li>itheima</li>';
html = html.repeat(10);

(五)新增对象Set

数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。
Set本身是一个构造函数,用来生成 Set 数据结构。
Set的特点就是该对象里面的成员不会有重复。

1.基本使用:
let set = new Set(); 得到一个空的Set对象。

2.Set的成员

  • size:属性,获取 set 中成员的个数,相当于数组中的 length
  • add(value):添加某个值,返回 Set 结构本身。
  • delete(value):删除某个值,返回一个布尔值,表示删除是否成功。
  • has(value):返回一个布尔值,表示该值是否为Set的成员。
  • clear():清除所有成员,没有返回值。
    let set = new Set();
    //调用set对象内置的add方法,想set中添加数据。
    set.add(3);
    set.add(8);
    set.add(9);
    set.add(3); //添加失败但不报错,set中的成员不能重复
    console.log(set); // {3,8,9}
    console.log(set.size); //3

初始化Set的时候,也可以为其传入数组或字符串,得到的Set对象中的成员不会有重复。根据这个特点可以完成数组或字符串去重。

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

推荐阅读更多精彩内容

  • 这是16年5月份编辑的一份比较杂乱适合自己观看的学习记录文档,今天18年5月份再次想写文章,发现简书还为我保存起的...
    Jenaral阅读 2,739评论 2 9
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,378评论 0 5
  • 什么是箭头函数?看下面的语法。 为什么要用箭头函数?一个字:短。 1 箭头函数最大的优点就是简短。 2 箭头函数不...
    Condy康迪阅读 3,575评论 0 5
  • 1、Promise的涵义 promise是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理且更...
    叶苏芒阅读 453评论 0 0
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,219评论 0 4