ES 6语法

目录

1.let、const
2.箭头函数
3.模板字符串
4.解构赋值
5.rest参数
6.扩展运算符
7.class
8.import、export

1.let、const

let和const 是ES 6中新增的两个关键字,用来声明变量,let 和 const 都是块级作用域。
let声明的变量只在let命令所在的代码块有效。
const声明的一个只读的常量,一旦声明,常量的值就不能发生改变

例如:

let a = 1;
var b = 2;

const c = 3;

2.箭头函数

ES6 允许使用"箭头"(=>)定义函数。这种方式创建的函数不需要function关键字,并且还可以省略return关键字。
同时,箭头函数内的 this 指向函数定义时所在的上下文对象,而不是函数执行时的上下文对象。

let f = a => a + 1;
// 等价于
let f = function(a) {
  return a + 1;
}

function foo() {
  this.bar = 1;
  this.f = (a) => a + this.bar
}

// 等价于
function foo() {
  this.bar = 1;
  this.f = (function(a) {
    return a + this.bar
  }).bind(this)
}

如果箭头函数的参数多于1个或者不需要参数,就需要使用一个圆括号代表参数。

let e = () => 4;
let g = (a, b) => a + b;

如果函数体内包含的语句多于一条,就需要使用大括号将函数体括起来,使用return语句返回

let f2 = (x, y) => {
  x++;
  y++;
  return x + y
}

3.模板字符串

模板字符串是增强版的字符串,用反引号(')标识字符串。除了可以当作普通字符串使用外,它还可以用来定义多行字符串,以及在字符串中嵌入变量,功能很强大。

//普通字符串
let text = "React is Wonderful !";

//多行字符串
let text2 = `JS is Wonderful !
React is Wonderful !`

//字符串中嵌入变量
let name = "React";
let name2 = `Hello, ${name} !`;

4.解构赋值

ES6允许按照一定模式从数组和对象中提取值,对变量进行赋值,这被称为解构。

//数组解构
let [a1, b1, c1] = [1, 2, 3];
console.log(a1) // 1
console.log(b1) // 2
console.log(c1) // 3
//对象解构
let name3 = "Lily";
let age = 14;
let person = {
  name3, age
};
console.log(person)
// { name3: 'Lily', age: 14 }
//对象解构的另一种形式
let person = {
  name: "Lily",
  age: 14
};
let { name, age } = person;

console.log(person) // { name: 'Lily', age: 14 }
console.log(name) // Lily
console.log(age) // 14

函数的参数也可以使用解构赋值。

//函数的参数也可以使用解构赋值。

//数组解构参数
function sum([x, y]) {
  return x + y;
}

let value = sum([1, 2]);
console.log(value) // 3

//对象参数解构
function sum2({ x, y }) {
  return x + y;
}

let value2 = sum2({ x: 1, y: 3 })
console.log(value2) // 4

解构同样适用于嵌套解构的数组或对象

//嵌套解构的数组解构

let [z, [x], v] = [1, [2], 3];
console.log(z) // 1
console.log(x) // 2
console.log(v) // 3

//嵌套解构的对象解构
let { person: { name, age }, foo3 } = {
  person: {
    name: "Lily",
    age: 4,
  }, foo3: "foo"
};
console.log(name) // Lily
console.log(age)  // 4
console.log(foo3) // foo

5.rest参数

ES6 引入rest参数(形式为...变量名)用于获取函数的多余参数,以代替 arguments 对象的使用。
rest 参数是一个数组,数组中的元素是多余的参数。

注意,rest参数后不能再有其他参数。
//ES6 引入rest参数(形式为...变量名)用于获取函数的多余参数,以代替 arguments 对象的使用。
//rest 参数是一个数组,数组中的元素是多余的参数。
//注意,rest参数后不能再有其他参数。

function languages(lang, ...types) {
  console.log(types)
}

languages("JS", "java", "php")

6.扩展运算符

//扩展运算符是三个点(...),它将一个数组转为用逗号分隔的参数序列,类似于rest参数的逆运算。
function sum(a, b, c) {
  return a + b + c;
}

let numbers = [1, 2, 3];
sum(...numbers)
console.log(sum(...numbers)) // 6

//扩展运算符还常用于合并数组以及与解构值结合使用
//合并数组
let arr1 = ["a"];
let arr2 = ["b", "c"];
let arr3 = ["d", "e"];
let arr4 = [...arr1, ...arr2, ...arr3];
console.log(arr4) // [ 'a', 'b', 'c', 'd', 'e' ]

//与解构赋值结合
let [m, ...rest] = ["a", "b", "c"];
console.log(rest) // [ 'b', 'c' ]

//扩展运算符还可以用于取出参数对象的所有可遍历属性,复制到当前对象之中。
let bar = { a: 1, b: 2 };
let foo5 = { ...bar };
console.log(foo5) // { a: 1, b: 2 }

7.class

ES6引入了class(类)这个概念,新的class写法让对象原型的写法更加清晰,也更像传统的面向对象编程语言的写法

//ES6引入了class(类)这个概念,新的class写法让对象原型的写法更加清晰,也更像传统的面向对象编程语言的写法
//定义一个类
class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }

  getName() {
    return this.name;
  }

  getAge() {
    return this.age;
  }
}

//根据类创建对象
let person = new Person("Lily", 4);
console.log(person) // Person { name: 'Lily', age: 4 }
console.log(person.getAge()) // 4
console.log(person.getName()) // Lily

//class之间可以通过 extends 关键字实现继承
class Man extends Person {
  constructor(name, age) {
    super(name, age)
  }
}

let man = new Man("Jack", 20);
console.log(man) // Man { name: 'Jack', age: 20 }
console.log(man.getName()) // Jack

8.import、export

ES6 实现了自己的模块化标准,ES6 模块功能主要由两个关键字构成:export 和 import 。
export 用于规定模块对外暴露的接口,
import 用于引入其他模块提供的接口

const foo = () => "foo";

//导出默认接口
export default foo;

const bar = () => "bar";
//导出普通接口
export { bar };

//注意默认接口和普通接口导入的区别
import foo, { bar } from "a"

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

推荐阅读更多精彩内容

  • 以下内容是我在学习和研究ES6时,对ES6的特性、重点和注意事项的提取、精练和总结,可以做为ES6特性的字典;在本...
    科研者阅读 3,126评论 2 9
  • ES6可以说是一个泛指,指5.1版本以后的JavaScript的下一代标准,涵盖了ES2015,ES2016,ES...
    lllhy阅读 358评论 0 0
  • 最近在做毕业设计,其中用到了一些 ES6 的语法,比如模块的输出引入,箭头函数,对象字面量的简写,等等。所性顺便就...
    小乌龟变王八阅读 489评论 0 0
  • ES6可以说是一个泛指,指5.1版本以后的JavaScript的下一代标准,涵盖了ES2015,ES2016,ES...
    Ming_Hu阅读 357评论 0 1
  • 前言 ECMAScript 6.0(简称ES6),作为下一代JavaScript的语言标准正式发布于2015 年 ...
    小雨雪smile阅读 1,492评论 0 50