iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >es6语法是不是一种标准
  • 663
分享到

es6语法是不是一种标准

2023-07-04 10:07:08 663人浏览 安东尼
摘要

本文小编为大家详细介绍“es6语法是不是一种标准”,内容详细,步骤清晰,细节处理妥当,希望这篇“es6语法是不是一种标准”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。es6语法是一种标准。ES6全称是ECMASc

本文小编为大家详细介绍“es6语法是不是一种标准”,内容详细,步骤清晰,细节处理妥当,希望这篇“es6语法是不是一种标准”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

es6语法是一种标准。ES6全称是ECMAScript 6,是正式发布的javascript语言的一种标准,该标准的目标是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言。ECMAScript和JavaScript的关系是:前者是后者的规格,后者是前者的一种实现。

ES6全称是ECMAScript 6,是正式发布的JavaScript语言的一种标准,该标准的目标是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言。

ES6是继ES5之后发布的JavaScript语言的新一代标准,加入了很多新的特性和语法,该标准于2015年6月17日发布了正式版本,并被正式命名为ES2015。

ECMAScript 和 JavaScript 的关系是,前者是后者的规格,后者是前者的一种实现(另外的 ECMAScript 方言还有 jscript 和 ActionScript)

2011 年,ECMAScript 5.1 版发布后,就开始制定 6.0 版了。因此,ES6 这个词的原意,就是指 JavaScript 语言的下一个版本。 ES6 的第一个版本,在 2015 年 6 月发布,正式名称是《ECMAScript 2015 标准》(简称 ES2015)。 2016 年 6 月,小幅修订的《ECMAScript 2016 标准》(简称 ES2016)如期发布,这个版本可以看作是 ES6.1 版,因为两者的差异非常小,基本上是同一个标准。根据计划,2017 年 6 月发布 ES2017 标准。

因此,ES6 既是一个历史名词,也是一个泛指,含义是 5.1 版以后的 JavaScript 的下一代标准,涵盖了 ES2015、ES2016、ES2017 等等,而 ES2015 则是正式名称,特指该年发布的正式版本的语言标准。我 们说 ES6 的地方,一般是指 ES2015 标准,但有时也是泛指“下一代 JavaScript 语言”。

一、块作用域构造let和const

块作用域存在于:函数内部、块中(即:字符 “ { ” 与 “ } ” 之间的区域)

1.let声明

  • 通过var声明的变量存在变量提升机制,而let声明的变量不会被提升,可将变量的作用域限制在当前代码块中

//通过var声明的变量  //函数内部        function changeState(flag) {            if (flag) {                var color = "red"            } else {                console.log(color);                return null;            }        }        changeState(false);   //块中        {            var a = 1;        }        console.log("a=" + a);   //for循环中        for (var i = 0; i < 10; i++) {}        console.log("i=" + i);

es6语法是不是一种标准

 //通过let声明的变量            //函数内部            function changeState(flag) {                if (flag) {                    let color = "red"                } else {                    console.log(color);                    return null;                }            }            changeState(false);                   //块中            {                let a = 1;            }            console.log("a=" + a);                  //for循环中            for (let i = 0; i < 10; i++) {}            console.log("i=" + i);

es6语法是不是一种标准

  • 在同一作用域下,不能使用let重复声明已经存在的标识符,但如果在不同的作用域下,则是可以的。

// 在同一作用域下,不能使用let重复声明已经存在的标识符,但如果在不同的作用域下,则是可以的    var a=0;    var b=0;    {        let a=0;    }    let b=0;

es6语法是不是一种标准

  • 使用let声明变量,可以防止变量的重复声明

 var a=0;        var a=10;//ok        var b=1        let b=100;

es6语法是不是一种标准

2.const声明

  • 每个通过const关键字声明的变量必须在声明的同时进行初始化

  • 在同一作用域下用const声明已经存在的标识符也会导致语法错误

  • 使用const声明对象,对象本身的绑定不能修改,但对象的属性和值是可以修改的

   const person={            name:"zhangSan"        };        person.name="lisi"; //ok        person.age=19;//ok                person={            name:"wangwu"        };

es6语法是不是一种标准

3.全局块作用域绑定

  • 在全局作用域中使用var声明的变量或对象,将作为浏览器环境中的window对象的属性(使用var很可能会无意中覆盖一个已经存在的全局属性)

 var greeting="welcome";        console.log(window.greeting);        console.log(window.Screen);        var Screen="liquid crystal";        console.log(window.Screen);

es6语法是不是一种标准

  • 使用let或const声明变量和常量,避免覆盖window对象的属性

 let greeting="welcome";        console.log(window.greeting);        console.log(window.Screen);        const Screen="liquid crystal";        console.log(window.Screen==Screen);

es6语法是不是一种标准

总结

  • 通过var声明的变量存在变量提升机制,而let声明的变量不会被提升,可将变量的作用域限制在当前代码块中

  • 在同一作用域下,不能使用let重复声明已经存在的标识符,但如果在不同的作用域下,则是可以的

  • 使用let声明变量,可以防止变量的重复声明

  • 每个通过const关键字声明的变量必须在声明的同时进行初始化

  • 在同一作用域下用const声明已经存在的标识符也会导致语法错误

  • 使用const声明对象,对象本身的绑定不能修改,但对象的属性和值是可以修改的

  • 在全局作用域中使用var声明的变量或对象,将作为浏览器环境中的window对象的属性(使用var很可能会无意中覆盖一个已经存在的全局属性)

  • 使用let或const声明变量和常量,避免覆盖window对象的属性

二、解构赋值

解构赋值是对赋值运算符的扩展。

他是一种针对数组或者对象进行模式匹配,然后对其中的变量进行赋值。

在代码书写上简洁且易读,语义更加清晰明了;

也方便了复杂对象中数据字段获取。

//1、数组解构// 传统let a = 1, b = 2, c = 3console.log(a, b, c)// ES6let [x, y, z] = [1, 2, 3]console.log(x, y, z)//2、对象解构let user = {name: 'Johon', age: 18}// 传统let name1 = user.namelet age1 = user.ageconsole.log(name1, age1)// ES6let { name, age } = user//注意:解构的变量必须和user中的属性同名console.log(name, age)

三、模板字符串

模板字符串相当于加强版的字符串,用反引号 `,除了作为普通字符串,还可以用来定义多行字符串,

还可以在字符串中加入变量和表达式。

// 字符串插入变量和表达式。变量名写在 ${} 中,${} 中可以放入 JavaScript 表达式。let name = 'Kuangshen'let age = 27let info = `My Name is ${name},I am ${age+1} years old next year.`console.log(info)// My Name is Kuangshen,I am 28 years old next year.

四、声明对象简写

const age = 12const name = '小王'// 传统const person1 = {age: age, name: name}console.log(person1)// ES6const person2 = {age, name}console.log(person2) //{age: 12, name: '小王'}

五、定义方法简写

// 传统const person1 = {sayHi:function(){console.log('Hi')}}person1.sayHi();//'Hi'// ES6const person2 = {sayHi(){console.log('Hi')}}person2.sayHi() //'Hi'

六、对象拓展运算符

符号 (...)

let person = {nameL:"oAk",age:23}let someone1 = persion // 引用赋值let someone2 = { ...person } // 对象拷贝someone1.name = 'oAk_OLD'someone2.name = 'oAk_NEW'console.log(persion) // {name:'oAk_OLD', age:23}console.log(someone1) // {name:'oAk_OLD', age:23}console.log(someone2) // {name:'oAk_NEW', age:23}

读到这里,这篇“es6语法是不是一种标准”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: es6语法是不是一种标准

本文链接: https://www.lsjlt.com/news/344156.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • es6语法是不是一种标准
    本文小编为大家详细介绍“es6语法是不是一种标准”,内容详细,步骤清晰,细节处理妥当,希望这篇“es6语法是不是一种标准”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。es6语法是一种标准。ES6全称是ECMASc...
    99+
    2023-07-04
  • require是不是es6语法
    本篇内容主要讲解“require是不是es6语法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“require是不是es6语法”吧!不是,require是CommonJS规范的模块化语法;而es6...
    99+
    2023-07-04
  • concat是不是es6语法
    这篇文章主要介绍“concat是不是es6语法”,在日常操作中,相信很多人在concat是不是es6语法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”concat是不是es6语法”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-04
  • es6 class是不是语法糖
    这篇文章主要介绍了es6 class是不是语法糖的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇es6 class是不是语法糖文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
  • let是不是es6的语法
    这篇文章主要介绍了let是不是es6的语法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇let是不是es6的语法文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
  • class类是不是es6语法
    本文小编为大家详细介绍“class类是不是es6语法”,内容详细,步骤清晰,细节处理妥当,希望这篇“class类是不是es6语法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。class类是es6语法,是es6新增...
    99+
    2023-07-04
  • bootstrap是不是一种语言
    小编给大家分享一下bootstrap是不是一种语言,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! bootstrap不是一种语言,而是一个前端js框架。boot...
    99+
    2024-04-02
  • go是不是一种语言
    这篇“go是不是一种语言”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“go是不是一种语言”文章吧。go是一种语言。Go(又称...
    99+
    2023-07-04
  • 供应商是一种标准方法还是已经过时了?
    来到编程网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《供应商是一种标准方法还是已经过时了?》,介绍一下,希望对大家的知识积累有所帮助,助力实战...
    99+
    2024-04-05
  • mysql是不是一种语言
    这篇文章主要介绍了mysql是不是一种语言,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。MySQL是一种关系型数据库管理系统,它不是一种语言。M...
    99+
    2024-04-02
  • javascript是不是一种脚本语言
    这篇文章将为大家详细讲解有关javascript是不是一种脚本语言,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 是,javascript是一...
    99+
    2024-04-02
  • react是不是JavaScript语言的一种
    这篇文章主要为大家展示了“react是不是JavaScript语言的一种”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“react是不是JavaScript语言的...
    99+
    2024-04-02
  • php和html5是不是一种语言
    今天给大家介绍一下php和html5是不是一种语言。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。php和html5不是一种语...
    99+
    2024-04-02
  • sql是不是层次数据库的标准语言
    这篇文章将为大家详细讲解有关sql是不是层次数据库的标准语言,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。sql语言不是层次数据库的标准语言,是关系数据库的标准语言。结构...
    99+
    2024-04-02
  • assign是不是es6方法
    这篇文章将为大家详细讲解有关assign是不是es6方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 assign是es6方法。assign...
    99+
    2024-04-02
  • filter是不是es6的方法
    这篇“filter是不是es6的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“filt...
    99+
    2024-04-02
  • Go究竟是不是一种编程语言?
    “Go究竟是不是一种编程语言?” Go语言,简称为Golang,是由Google开发的一种开源编程语言。自2009年首次发布以来,Go语言在编程界迅速崛起,并吸引了众多开发者的注意和青...
    99+
    2024-04-02
  • es6 map成员是不是唯一的
    今天小编给大家分享一下es6 map成员是不是唯一的的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。es6 map成员是唯一的...
    99+
    2023-07-04
  • 对自定义错误类型分类是否有一种标准方法
    积累知识,胜过积蓄金银!毕竟在Golang开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《对自定义错误类型分类是否有一种标准...
    99+
    2024-04-05
  • map是不是es6中的方法
    这篇文章主要讲解了“map是不是es6中的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“map是不是es6中的方法”吧! m...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作