ES6新特性

这里是修真院前端小课堂,每篇分享文从html

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】前端

八个方面深度解析前端知识/技能,本篇分享的是:数组

【ES6新特性】浏览器

1.背景介绍函数

ECMAScript 6(ES6) 目前基本成为业界标准,它的普及速度比 ES5 要快不少, 主要缘由是现代浏览器对 ES6 的支持至关迅速,尤为是 Chrome 和 Firefox 浏览器,已经支持 ES6 中绝大多数的特性。 下面逐一为你们详解经常使用的ES6新特性:this

2.知识剖析
CONST和LET
ES6推荐使用let声明局部变量,相比以前的var(不管声明在何处,都会被视为声明在函数的最顶部) let和var声明的区别: var x = '全局变量';{ let x = '局部变量'; console.log(x); // 局部变量}console.log(x); // 全局变量 let表示声明变量,而const表示声明常量,二者都为块级做用域;const 声明的变量都会被认为是常量,意思就是它的值被设置完成后就不能再修改了: const a = 1a = 0 //报错 若是const的是一个对象,对象所包含的值是能够被修改的。抽象一点儿说,就是对象所指向的地址没有变就行: const student = { name: 'cc' }student.name = 'yy';// 不报错student = { name: 'yy' };// 报错 有几个点须要注意:编码

let 关键词声明的变量不具有变量提高(hoisting)特性 let 和 const 声明只在最靠近的一个块中(花括号内)有效 当使用常量 const 声明时,请使用大写变量,如:CAPITAL_CASING const 在声明时必须被赋值code

 

模板字符串
在ES6以前,咱们每每这么处理模板字符串: 经过“”和“+”来构建模板 $("body").html("This demonstrates the output of HTML content to the page, including student's" + name + ", " + seatNumber + ", " + sex + " and so on."); 而对ES6来讲 基本的字符串格式化。将表达式嵌入字符串中进行拼接。用${}来界定; ES6反引号(`)直接搞定; $("body").html(This demonstrates the output of HTML content to the page, including student's ${name}, ${seatNumber}, ${sex} and so on.`);htm

 

箭头函数对象

ES6 中,箭头函数就是函数的一种简写形式,使用括号包裹参数,跟随一个 =>,紧接着是函数体; 箭头函数最直观的三个特色。 不须要 function 关键字来建立函数 省略 return 关键字 继承当前上下文的 this 关键字 // ES5var add = function (a, b) { return a + b;};// 使用箭头函数var add = (a, b) => a + b;// ES5[1,2,3].map((function(x){ return x + 1;}).bind(this)); // 使用箭头函数[1,2,3].map(x => x + 1); 细节:当你的函数有且仅有一个参数的时候,是能够省略掉括号的。当你函数返回有且仅有一个表达式的时候能够省略{} 和 return;

 

SPREAD / REST 操做符

Spread / Rest 操做符指的是 ...,具体是 Spread 仍是 Rest 须要看上下文语境。 当被用于迭代器中时,它是一个 Spread 操做符: function foo(x,y,z) { console.log(x,y,z);} let arr = [1,2,3];foo(...arr); // 1 2 3 当被用于函数传参时,是一个 Rest 操做符:当被用于函数传参时,是一个 Rest 操做符: function foo(...args) { console.log(args);}foo( 1, 2, 3, 4, 5); // [1, 2, 3, 4, 5]

 

对象和数组解构

// 对象const student = { name: 'Sam', age: 22, sex: '男'}// 数组// const student = ['Sam', 22, '男'];// ES5;const name = student.name;const age = student.age;const sex = student.sex;console.log(name + ' --- ' + age + ' --- ' + sex);// ES6const { name, age, sex } = student;console.log(name + ' --- ' + age + ' --- ' + sex);

 

 

对象超类

ES6 容许在对象中使用 super 方法: var parent = { foo() { console.log("Hello from the Parent"); }} var child = { foo() { super.foo(); console.log("Hello from the Child"); }} Object.setPrototypeOf(child, parent);child.foo(); // Hello from the Parent // Hello from the Child

 

 

PROMISE

setTimeout(function(){ console.log('Yay!') }, 1000) 咱们能够用ES6中的Promise重写: var wait1000 = new Promise(function(resolve, reject) { setTimeout(resolve, 1000) }).then(function() { console.log('Yay!') }) 或者用ES6的箭头函数:var wait1000 = new Promise((resolve, reject)=> { setTimeout(resolve, 1000) }).then(()=> { console.log('Yay!') }) 到如今为止,咱们只是单纯增长了代码的行数,还明显没有带来任何好处,你说的对。可是若是咱们有更多复杂的逻辑内嵌在setTimeout()中的回调时好处就来了:

setTimeout(function(){ console.log('Yay!') setTimeout(function(){ console.log('Wheeyee!') }, 1000) }, 1000) ES6中的Promise重写: var wait1000 = ()=> new Promise((resolve, reject)=> {setTimeout(resolve, 1000)}) wait1000() .then(function() { console.log('Yay!') return wait1000() }) .then(function() { console.log('Wheeyee!') }); 仍是没法相信Promise比普通回调要好?我也不信。我想一旦知道了回调这个方法它就会在你脑中萦绕,额外的复杂的Promise也没有必要存在了。

 

 

3.常见问题
解构赋值还有什么用法?

 

 

4.解决方案
 

 

let {log,warn} = console; log('hello'); console.log('hello')

 

 

5.编码实战
 

 

 

6.扩展思考
7.参考文献
参考一: ES6中经常使用的10个新特性讲解

 

参考二: ES6类的概念

 

8.更多讨论

 

1,什么是块级做用域

 

let实际上为 JavaScript 新增了块级做用域。

 

function f1() {

  let n = 5;

  if (true) {

    let n = 10;

  }

  console.log(n); // 5

}

 

上面的函数有两个代码块,都声明了变量n,运行后输出 5。这表示外层代码块不受内层代码块的影响。若是两次都使用var定义变量n,最后输出的值才是 10。

 

2.const用法?

const声明一个只读的常量。一旦声明,常量的值就不能改变。const的做用域与let命令相同:只在声明所在的块级做用域内有效。

 

3,对象简写使用?

 

function f(x, y) {

  return {x, y};

}

// 等同于

function f(x, y) {

  return {x: x, y: y};

}

f(1, 2) // Object {x: 1, y: 2}

相关文章
相关标签/搜索