es6有什么新加的东西

es6新增的特性:1、用const和let声明变量,两种变量都为块级作用域;2、模板字符串,语法“`字符串`”,可使字符串拼接更简洁;3、箭头函数,可很好解决this指向问题;4、延展操作符,将可迭代对象展开到其单独的元素中;5、模块化等。

es6有什么新加的东西

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

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

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

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

在之前JS是没有块级作用域的,const与let填补了这方便的空白,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_CASINGconst 在声明时必须被赋值

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反引号(“)直接搞定;

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的简写,它还带来了其它好处。箭头函数与包围它的代码共享同一个this,能帮你很好的解决this的指向问题。有经验的JavaScript开发者都熟悉诸如var self = this;或var that = this这种引用外围this的模式。但借助=>,就不需要这种模式了。

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

不需要 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;

4. 函数的参数默认值

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

// ES6之前,当未传入参数时,text = 'default';function printText(text) {    text = text || 'default';    console.log(text);}// ES6;function printText(text = 'default') {    console.log(text);}printText('hello'); // helloprintText();// default

登录后复制

5.延展操作符(Spread operator)

延展操作符 … 是ES6中引入的,将可迭代对象展开到其单独的元素中,所谓的可迭代对象就是任何能用for of循环进行遍历的对象,例如:数组、字符串、Map 、Set 、DOM节点等。

延展操作符…可以在函数调用/数组构造时, 将数组表达式或者string在语法层面展开;还可以在构造对象时, 将对象表达式按key-value的方式展开。

当被用于迭代器中时,它是一个 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);// ES6const { 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 letter = ['a', 'b', 'c'];letter.size = 3;for (let letter of letters) {  console.log(letter);}// 结果: a, b, c

登录后复制

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

let stu = ['Sam', '22', '男'];stu.size = 3;for (let stu in stus) {  console.log(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); // functionlet 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()。在 这里 阅读更多关于类的介绍。

有几点值得注意的是:

类的声明不会提升(hoisting),如果你要使用某个 Class,那你必须在使用之前定义它,否则会抛出一个 ReferenceError 的错误在类中定义函数不需要使用 function 关键词

11、模块化(Module)

ES5不支持原生的模块化,在ES6中模块作为重要的组成部分被添加进来。模块的功能主要由 export 和 import 组成。每一个模块都有自己单独的作用域,模块之间的相互调用关系是通过 export 来规定模块对外暴露的接口,通过import来引用其它模块提供的接口。同时还为模块创造了命名空间,防止函数的命名冲突。

导出(export)

ES6允许在一个模块中使用export来导出多个变量或函数。

导出变量

//test.jsexport var name = 'Rainbow'

登录后复制

心得:ES6不仅支持变量的导出,也支持常量的导出。 export const sqrt = Math.sqrt;//导出常量

ES6将一个文件视为一个模块,上面的模块通过 export 向外输出了一个变量。一个模块也可以同时往外面输出多个变量。

 //test.js var name = 'Rainbow'; var age = '24'; export {name, age};

登录后复制

导出函数

// myModule.jsexport function myModule(someArg) {  return someArg;}

登录后复制

导入(import)

定义好模块的输出以后就可以在另外一个模块通过import引用。

import {myModule} from 'myModule';// main.jsimport {name,age} from 'test';// test.js

登录后复制

心得:一条import 语句可以同时导入默认函数和其它变量。import defaultMethod, { otherMethod } from ‘xxx.js’;

【相关推荐:javascript视频教程、web前端】

以上就是es6有什么新加的东西的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2933889.html

(0)
上一篇 2025年3月11日 20:36:37
下一篇 2025年2月21日 17:30:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • es6静态属性和实例属性的区别是什么

    区别:1、静态属性是类自身的属性,只能在类自身调用,而实例属性是实例对象的属性;2、实例对象无法调用静态属性,但类可调用实例属性;3、静态属性只有一种声明方法,语法“类名.属性名=值”,而实例属性有多种声明方法,例类中用“属性名=值”定义。…

    2025年3月11日
    000
  • 修饰器是es6还是es7的特性

    修饰器是es7特性。修饰器是ES7引入的一种与类相关的语法,用来注释或修改类和类的方法,依赖于ES5的“Object.defineProperty”方法,写法为“@函数名”;它可以注入到类、方法、属性参数上来扩展类、属性、方法、参数的功能。…

    2025年3月11日
    200
  • es6 match()有几个参数

    es6 match()只要一个参数。match()方法用于检索匹配项,可以在字符串内检索指定的值,或找到一个或多个正则表达式的匹配,语法“String.match(regexp)”;该方法只要一个参数,用于规定要匹配的模式的正则表达式对象。…

    2025年3月11日
    200
  • ES6怎么修改数组中的某个元素

    修改方法:1、使用“数组名[指定下标值]=新值;”语法,通过下标访问指定元素,并给该元素重新赋值来进行修改;2、使用“array.splice(开始文章,删除元素个数,插入值1插入值2)”语句,从指定位置开始删除n个元素,并插入n个新元素。…

    2025年3月11日
    200
  • es6的set和map的区别是什么

    区别:1、set指的是“集合”结构,而Map指的是“字典”结构;2、set是以“[value, value]”的形式储存元素,而Map是以“[key, value]”的形式储存;3、Map可用get()通过键查找特定值并返回,而set不行。…

    2025年3月11日
    200
  • es6数组怎么去掉规定的值

    去掉方法:1、用“arr.splice(arr.indexOf(“指定值”),1)”语句,用indexOf()查找指定值的位置,再用splice()根据位置删除该元素;2、用“delete arr[arr.index…

    2025年3月11日
    200
  • es6中let与var的区别是什么

    区别:1、let变量有块级作用域,而var变量没有块级作用域;2、var变量存在变量提升(无暂时性死区约束),可以先使用再声明,而let变量不存在变量提升(有暂时性死区约束),必须先声明再使用;3、let变量不能重复声明,而var变量可以。…

    2025年3月11日
    200
  • 什么是es6模块化

    es6模块化是浏览器端与服务器端通用的模块化开发规范,其设计思想是尽量的静态化,使得编译时就能确定模块的依赖关系,及输入和输出的变量。在ES6模块化中,每个js文件都是一个独立的模块,导入模块用import关键字,导出用expost关键字。…

    2025年3月11日
    200
  • es6中数组新增常用的4个方法是什么

    es6中数组新增常用的4个方法是:1、forEach(),用于遍历数组,无返回值;2、filter(),过滤掉数组中不满足条件的值;3、map(),遍历数组,返回一个新数组;4、reduce(),让数组的前后两项进行某种计算,然后返回其值。…

    2025年3月11日 编程技术
    200
  • es6可以用双引号吗

    es6可以用双引号。在es6中,可用双引号来定义字符串,字符串就是一段以单引号或双引号包裹起来的文本,语法“var 变量名=”字符串文本”;”;若引号中用引号,需采取“外双内单”或“外单内双”格式,保证内外引号是不一…

    2025年3月11日
    200

发表回复

登录后才能评论