美文网首页
React系列(四):ECMAScript6.0的使用(下)

React系列(四):ECMAScript6.0的使用(下)

作者: 繁华落殇 | 来源:发表于2018-01-29 17:44 被阅读0次

    随着google和firfox以及node6.0对ES6的支持,ES6语法的定稿使它越来越受到关注,尤其是react项目基本上都是用ES6来写的。本文主要就是对ES6基础语法做出解析,为后续的React知识点做好铺垫,主要内容如下:

    default, rest: 函数默认值,变量展开

    import, export:导入,输出

    as:修改变量名

    :模块整体加载**

    Map的使用方式

    Set的使用方式

    新增的核心库

    1. default, rest: 函数默认值,变量展开

    1.1 默认值操作

    ES5对于函数参数的默认值操作:

    default是默认值,应用于函数传参个数不匹配时。

    ES6中的函数参数默认值设定:

    1.2 变量展开

    rest是变量展开:

    2. import, export:导入,输出

    历史上,JavaScript一直没有模块(module)体系,无法将一个大程序拆分成互相依赖的小文件,再用简单的方法拼装起来。其他语言都有这项功能,比如Ruby的require、Python的import,甚至就连CSS都有@import, 但是JavaScript任何这方面的支持都没有,这对开发大型的、复杂的项目形成了巨大障碍。

    es6中新增了两个命令export和import,export命令用于规定es6模块的对外接口,import 命令用于输入其他es6模块化提供的功能。一个es6模块就是一个独立的文件。该文件内部的所有变量,外部无法获取。如果你希望外部能够读取模块内部的某个 变量, 就必须使用export关键字输出该变量。下面是一个JS文件,里面使用export命令输出变量。

    2.1 index.js书写

    如下是三种模块化写法的对比

    requireJS 的使用方式

    CommonJS 的写法

    ES6的写法

    2.2 content.js书写

    如下是三种模块化写法的对比

    requireJS 的使用方式

    CommonJS 的写法

    ES6的写法

    3. *:模块整体加载 && as:修改变量名

    修改变量名使用as;

    除了指定加载某个输出值,还可以使用整体加载,即用星号(*)指定一个对象,所有输出值都加载在这个对象上面。

    4. Map的使用方法

    Map的size属性,获取Map数据格式的内容个数,其方法如下:

    set方法,给Map设置一个属性;

    get方法,获取Map数据格式中的某条属性;

    has方法,判断Map数据中是否拥有某条属性,return 布尔值;

    delete方法,删除Map数据格式中的某条属性;

    clear方法,删除Map数据格式中的所有数据。

    方法使用如下:

    Map支持for…of语句

    支持数组\字符串

    5. Set的使用方法

    Set类似数组,成员都是唯一,不存在重复值:

    Set的应用:数组去重;

    add方法,新增一个数据;

    size属性,获取当前Set的长度;

    has方法:判断成员是否属于当前Set,返回布尔值;

    delete方法,删除Set中的某条属性。

    方法使用:

    支持添加方法add:

    6. 新增核心库

    增加了Number、Math、Array等方法,使得原本的JS逻辑更加清晰简单,如下:

    总结

    本文与上一篇文章都是对ES6语法的深入解读,旨在提供简化开发难度,使得JS逻辑、方法更简便。

    使用到的代码文件可下载:链接:https://pan.baidu.com/s/1dGsYuyt 密码:6t3g

    相关文章

      网友评论

          本文标题:React系列(四):ECMAScript6.0的使用(下)

          本文链接:https://www.haomeiwen.com/subject/pthfzxtx.html