ES6中常用的10个新特性讲解

ECMAScript 6(ES6) 目前基本成为业界标准,它的普及速度比 ES5 要快很多,主要原因是现代浏览器对 ES6 的支持相当迅速,尤其是 Chrome 和 Firefox 浏览器,已经支持 ES6 中绝大多数的特性。

ES6

下面逐一为大家详解常用的ES6新特性:

1.不一样的变量声明:const和let

ES6推荐使用let声明局部变量,相比之前的var(无论声明在何处,都会被视为声明在函数的最顶部)

let和var声明的区别:var x = '全局变量'; { let x = '局部变量'; console.log(x); // 局部变量 } console.log(x); // 全局变量

let表示声明变量,而const表示声明常量,两者都为块级作用域;const 声明的变量都会被认为是常量,意思就是它的值被设置完成后就不能再修改了:

const a = 1 a = 0 //报错

如果const的是一个对象,对象所包含的值是可以被修改的。抽象一点儿说,就是对象所指向的地址没有变就行:

const student = { name: 'cc' } student.name = 'yy';// 不报错 student = { name: 'yy' };// 报错

有几个点需要注意:

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

在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.`);3.箭头函数(Arrow Functions)

ES6 中,箭头函数就是函数的一种简写形式,使用括号包裹参数,跟随一个 =>,紧接着是函数体;

箭头函数最直观的三个特点。

不需要 function 关键字来创建函数 省略 return 关键字 继承当前上下文的 this 关键字// ES5 var 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;

4. 函数的参数默认值

在ES6之前,我们往往这样定义参数的默认值:

// ES6之前,当未传入参数时,text = 'default'; function printText(text) { text = text || 'default'; console.log(text); } // ES6; function printText(text = 'default') { console.log(text); } printText('hello'); // hello printText();// default 5.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]6.二进制和八进制字面量

ES6 支持二进制和八进制的字面量,通过在数字前面添加 0o 或者0O 即可将其转换为八进制值:

let oValue = 0o10; console.log(oValue); // 8 let bValue = 0b10; // 二进制使用 `0b` 或者 `0B` console.log(bValue); // 2 7.对象和数组解构// 对象 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); // ES6 const { name, age, sex } = student; console.log(name + ' --- ' + age + ' --- ' + sex);8.对象超类

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 9.for...of 和 for...in

for...of 用于遍历一个迭代器,如数组:

let letters = ['a', 'b', 'c']; letters.size = 3; for (let letter of letters) { console.log(letter); } // 结果: a, b, c

for...in 用来遍历对象中的属性:

let stus = ["Sam", "22", "男"]; for (let stu in stus) { console.log(stus[stu]); } // 结果: Sam, 22, 男10.ES6中的类

ES6 中支持 class 语法,不过,ES6的class不是新的对象继承模型,它只是原型链的语法糖表现形式。

函数中使用 static 关键词定义构造函数的的方法和属性:

class Student { constructor() { console.log("I'm a student."); } study() { console.log('study!'); } static read() { console.log("Reading Now."); } } console.log(typeof Student); // function let stu = new Student(); // "I'm a student." stu.study(); // "study!" stu.read(); // "Reading Now."

类中的继承和超集:

class Phone { constructor() { console.log("I'm a phone."); } } class MI extends Phone { constructor() { super(); console.log("I'm a phone designed by xiaomi"); } } let mi8 = new MI();

extends 允许一个子类继承父类,需要注意的是,子类的constructor 函数中需要执行 super() 函数。

当然,你也可以在子类方法中调用父类的方法,如super.parentMethodName()。

(0)

相关推荐

  • 1.变量:var,let,const

    var在ECMAScript的所有版本中都可以使用,而const和let只能在ES6及更晚的版本中使用. var,let,const三个关键字的区别 var: 1)声明作用域:在函数内部,使用var定 ...

  • JS的绑定对象this

    this的含义 this表示的是绑定的对象,通常在函数中使用. 不同的代码形式下,绑定的对象代表不同的东西. 下面看一下常见的几种代码形式: 一.独立的函数 function foo() { cons ...

  • es6新增特性之函数参数默认值的优势-笔记

    ES6支持在定义函数的时候为其设置默认值: function foo(height = 50, color = 'red') { console.log(height); console.log(co ...

  • JavaScript 里三个点 ... 的用法

    Three dots ( - ) in JavaScript Rest Parameters 使用 rest 参数,我们可以将任意数量的参数收集到一个数组中,然后用它们做我们想做的事情. 引入了其余参 ...

  • 书法中常用的10种笔法,你学会了几种

    书圣王羲之曾在他的<书论>中提到"夫书者,玄妙之技也,若非通达人士,学无及之."元代著名书法大家赵孟頫也曾在<兰亭十三跋>中论述过"结字因时相传, ...

  • 普洱茶品鉴中常用的10个术语

    https://www.toutiao.com/w/a1702082138497038/ 1.回甘 指苦味在口中转化消失过程中产生的甜. 2.生津 指两颊.舌面.舌底.有小气泡不断地涌出. 3.舌底鸣 ...

  • 生活中常用到10种中成药,医院买不到,便...

    便宜效果好 1. 胃溃疡--便宜效果好--温胃舒胶囊 2. 腹部发胀--便宜效果好--香砂平胃丸 3. 睡眠差--便宜效果好--牛黄清心丸 4. 口腔溃疡--便宜效果好--复方珍珠散 5. 总是咳嗽- ...

  • EXCEL数据分析中常用的10个图表

    目录: 一.前言 二.EXCEL数据分析中常用的10个图表 三.EXCEL图表格式设置六元素(图表标题.坐标轴标题.图例.数据标签.坐标轴.网格线) 一.前言 在学习数据分析时,其中的一个学习板块就是 ...

  • 【收藏篇】Android 开发中常用的10种工具类

    导语 Android开发中,收集一些常用的代码工具类是非常重要的.现在Android开发技术已经很成熟了,很多代码大牛已经写出了很多框架和工具类,我们现在应该要站在巨人的肩膀上做开发了.今天我把平时开 ...

  • excel中常用的10个函数公式,直接套用即可

    excel中常用的10个函数公式,直接套用即可

  • PS中常用的10个功能讲解,非常适合新手

    PS中常用的10个功能讲解,非常适合新手

  • 古诗中常用的10个汉代典故(出处、用法)

    商山四皓 出处 上欲废太子,立戚夫人子赵王如意.大臣多谏争,未能得坚决者也.吕后恐,不知所为.人或谓吕后曰:「留侯善画计筴,上信用之.」吕后乃使建成侯吕泽劫留侯,曰:「君常为上谋臣,今上欲易太子,君安 ...

  • 助力30岁后中年男性生活常用的10种中....

    助力30岁后中年男性生活常用的10种中.成.药,一般店里不愿卖,但便宜好用 1.口臭.口腔溃疡--[牛黄解毒片] 用于:体内火气比较旺盛,经常牙龈痛,喉咙痛,频繁长口腔溃疡,口气比较重的. 2.咳嗽. ...