资讯专栏INFORMATION COLUMN

React项目中出现频率较高的ES6语法

ZHAO_ / 809人阅读

摘要:学习过程中,发现无论是上的还是相关文档,语法都有大量的使用。如下使用语法来定义一个组件有几个注意点使用了的继承语法,关键字这里使用了上面说的语法方法名的简写,注意方法之间不加是构造函数,可以替代。内需要调用父类的构造函数即,否则就会报错。

学习React过程中,发现无论是github上的Demo还是React相关文档,ES6语法都有大量的使用。如果不了解一些ES6语法,很难学习下去。如果转战ES6,系统学习战线又较长。所以把一些常用的ES6语法做一些总结,有助于读懂React,Redux的文档。特别提醒:一些细节学习还是需要仔细查阅文档。

可以通过这个在线工具写ES6代码:http://www.es6fiddle.net/

let&const

这两个关键字大家应该都有了解,主要是引入了块级作用域,不存在变量提升,不能重复定义等特性。const是用来定义常量的。
文档:http://es6.ruanyifeng.com/#do...

解构赋值

常规用法

let { x } = { x: 1, y: 2}
let { PropTypes } = React

这是对象的解构赋值,等同于let PropTypes = React.PropTypes(注意这里包含了两步:声明变量PropTypes&赋值为React.PropTypes)。

所以这样写也是OK的

let PropTypes
{ PropTypes } = React

可以同时写多变量,如

let { PropTypes, Component } = React

如果想定义的变量名和属性名不一样,可以这样写

let { x: x1 } = { x: 1, y: 2}

声明x1变量,并赋值为1。注意x是模式,不是变量也不会被赋值

除了对象,数组,字符串等都有解构赋值的用法。
看文档:http://es6.ruanyifeng.com/#do...

对象的拓展 属性的简洁表达方式
let x = "123"
let obj = { x, y: "33" }//等同于 let obj = { x: x, y: "33"}

如上代码所示,ES6允许对象内只写属性名,不写属性值,属性值就等于改与属性名相等的变量值

方法名也可以简写
let User = {
    method() { //等同于method: function(){
        //...
    }
}
属性名表达式
let key = "id"
let obj = {
   [key]: "1010",  //注意与 key: "1010" 的区别
   ["use" + "name" ]: "x"   
}

把表达式写在[]中,表达式的值作为字段名称。
注意属性名表达式与属性名简写不能同时使用。如下

let key = "id"
let id = "1010"
let obj = {
   [key]
}
ES6 Class

使用ES6语法来定义一个React组件

export class Counter extends React.Component {
  constructor(props) {
    super(props);
    this.state = {count: props.initialCount};
    this.tick = this.tick.bind(this);
  }

  tick() {
    this.setState({count: this.state.count + 1});
  }

  render() {
    return (
      
Clicks: {this.state.count}
); } } Counter.propTypes = { initialCount: React.PropTypes.number }; Counter.defaultProps = { initialCount: 0 };

有几个注意点:
使用了ES6的继承语法,关键字extends

这里使用了上面说的语法:方法名的简写,注意方法之间不加,

constructor是构造函数,可以替代getInitialStateconstructor内需要调用父类的构造函数即super(props),否则就会报错。因为子类没有自己的this对象,需要从父类继承。所以有用到this的语句需要写在super(props)之后。

this.tick = this.tick.bind(this);

这里使用bind来绑定执行的作用域(使用React.createClass是自动绑定的),也可在render中监听事件的地方写bind(this),如下:

Clicks: {this.state.count}

不过官方文档建议是统一写在constructor 中,这样该方法就只需要绑定一次。

除了使用bind(this),还可以使用箭头函数

this.tick()}> Clicks: {this.state.count}

这里就体现了箭头函数的特性:

函数体内的this就是定义时的对象,而不是调用时所在的对象。也就是说箭头函数的this指向是固定的,而普通函数是可变的。

箭头函数

ES6允许使用=>来定义函数

let f = v => v + 2
//等同于
let f = function(v){
    return v + 2
}

如果有多个参数

let f = (x, y) => x + y

函数体有多条语句,用大括号包起来

let f = (x, y) => {
    x = x + 1
    y = y + 3
    return x + y 
}

在总结ES6的class语法时也提到:箭头函数的this对象就是定义时所在的this对象,与执行时所在的对象无关
还有一点可以帮助理解:箭头函数的this指向能保持不变,不是因为内部有绑定的机制,而是箭头函数没有自己的this,导致代码内的this就是外层代码块的this
看文档:http://es6.ruanyifeng.com/#do...箭头函数

export&import

export用于输出模块对外的接口,import用于导入其他模块提供的功能。

export let client = "APP"  //输出变量
export function mul(x, y){  //输出函数
    return x + y
}
export class Toast(){} //输出类

也可以统一输出

//文件名 util.js
let client = "APP"  //输出变量
function mul(x, y){  //输出函数
    return x + y
}
export { client, mul }

对应的导入应该这样用:

//注意这里有大括号,并且名称和输出时保持一致
import { client, mul } from "./util.js" 

下面这样写也可以

import * as U from "./util.js"
U.client //使用

我们很常用还有export default命令,用于输出默认的方法,变量或类

export default React.createClass({ 
    // ...
})

引入的时候就比较方便,可以随意指定名字

import Tab from "tab"  //注意这里没有大括号

文档:http://es6.ruanyifeng.com/#do...

对象的拓展运算符...

拓展运算符属于ES7的提案,但babel已经支持,在Redux的示例Demo中很常见。
拓展运算符可以用来合并两个对象

//state = { name: "y" } 
return {...state, name: "x", id: 101 }
//返回 { name: "x", id: 101}

有两个点:取出state对象的所有可遍历属性,拷贝到当前对象上;如果自定义的属性放后面,拓展运算符的同名属性值则会覆盖掉。

这中用法等同与Object.assgin

Object.assgin({}, state, { name: "x", id: 101 })

使用拓展运算符需要安装transform-object-rest-spread插件,然后在babel中配置。配置如下:

test: /.js$/,
exclude: /node_modules/,
loader: "babel",
query:{
    presets: ["react", "es2015"],
    plugins: ["transform-object-rest-spread"]
}

文档:http://babeljs.io/docs/plugin...
http://es6.ruanyifeng.com/#do...对象的扩展运算符

推荐ES6教程:http://www.hubwiz.com/course/...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/79665.html

相关文章

  • 2019年前端的3个趋势

    摘要:组件成为前端最基本的物料,融合在组件中的方案日趋成熟。组件成为最基本的前端物料,让组件化更彻底在的调研报告中,开发者有愿意继续,有愿意继续。需要留意的是,有表示对感兴趣,因此获得的最感兴趣奖。 简介: JavaScript 应用范围广泛,静态类型语言 TypeScript 会继续得到更多开发者的青睐。 组件成为前端最基本的物料,CSS 融合在组件中(CSS in JS)的方案日趋成熟...

    yanwei 评论0 收藏0
  • React16时代,该用什么姿势写 React ?

    摘要:的返回值将作为的参数,如果返回,则不更新,不能返回或以外的值,否则会警告。在更新之前调用,此时已更新返回值作为的第个参数一般用于获取之前的数据语法是从的返回值,默认是的使用场景一般是获取组建更新之前的滚动条位置。 React16 后的各功能点是多个版本陆陆续续迭代增加的,本篇文章的讲解是建立在 16.6.0 版本上本篇文章主旨在介绍 React16 之后版本中新增或修改的地方,所以对于...

    Reducto 评论0 收藏0
  • 2018年前端面试题

    摘要:三月去面试了几家公司,不大不小,把面试时面试官问的问题总结一下供大家参考。很明显,面试时问题以及出现频率非常高,并且包括,在方面问的比较多的主要是跨域以及。面试时更侧重于在实际项目中,遇到问题你是怎么解决的。 三月去面试了几家公司,不大不小,把面试时面试官问的问题总结一下供大家参考。很明显,面试时问题vue以及react出现频率非常高,并且包括webpack,在JS方面问的比较多的主要...

    beita 评论0 收藏0
  • webpack优化

    摘要:使用要给项目构建接入动态链接库的思想,需要完成以下事情把网页依赖的基础模块抽离出来,打包到一个个单独的动态链接库中去。接入已经内置了对动态链接库的支持,需要通过个内置的插件接入,它们分别是插件用于打包出一个个单独的动态链接库文件。 webpack优化 查看所有文档页面:全栈开发,获取更多信息。原文链接:webpack优化,原文广告模态框遮挡,阅读体验不好,所以整理成本文,方便查找。 ...

    ChanceWong 评论0 收藏0
  • eslint总结

    摘要:初始命令初始命令如下生成文件自动修复错误。第一个是错误级别关闭规则将规则视为一个警告不会影响退出码将规则视为一个错误退出码为可以从基础配置中继承已启用的规则。一旦发现配置文件中有,它就会停止在父级目录中寻找。 1、初始命令 eslint初始命令如下: (1) eslint --init: 生成.eslintrc.js文件(2) eslint src --fix: 自动修复错误。但是只能...

    keke 评论0 收藏0

发表评论

0条评论

ZHAO_

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<