在React的render方法中使用箭头函数

在 React 组件中绑定点击事件通常的做法使用 class 属性。

class Foo extends Component {
  handleClick = () => {
    console.log('Click happened')
  }
  render() {
    return <button onClick={this.handleClick}>Click Me</button>;
  }
}

但是有时候为了更迅速的完成代码逻辑,我们也常常是直接写在 render 方法中。

class Foo extends Component {
  render() {
    return <button onClick={() => console.log('Click happened')}>Click Me</button>;
  }
}

并且使用箭头函数是向回调函数传递参数的最简单的办法。

注意:

在 render 方法中使用箭头函数也会在每次组件渲染时创建一个新的函数,这会破坏 React 基于恒等比较的性能优化。

Diffing 算法当对比两颗树时,React 首先比较两棵树的根节点。当对比两个相同类型的 React 元素时,React 会保留 DOM 节点,仅比对及更新有改变的属性。

如果你在 render 方法里创建函数。因为浅比较 props 的时候总会得到 false。

在大多数情况下,这没什么问题,但如果该回调函数作为 prop 传入子组件时,这些组件可能会进行额外的重新渲染。我们通常建议使用 class 属性的语法来避免这类性能问题。

import React from 'react';

class Child extends React.PureComponent {
  render () {
    console.log('导致重新渲染')
    return (
      <div>todo</div>
    )
  }
}

class Foo extends React.Component {
  state = {
    count: 0
  }
  handleClick = () => {
    this.setState({count: this.state.count+1})
  }
  render() {
    return (
      <div>
        <button onClick={this.handleClick}>{this.state.count}</button>
        <Child callbackFn={() => { console.log('在render方法中使用箭头函数') }} />
      </div>
    )
  }
}

export default Foo;

.PureComponent 的实现原理是通过浅层对比 prop 和 state 的方式来实现的。

如果你在 render 方法里创建函数。因为浅比较 props 的时候总会得到 false。所以通常还是把方法都写在实例上。

import React from 'react';

class Child extends React.PureComponent {
  render () {
    console.log('重新渲染')
    return (
      <div>todo</div>
    )
  }
}

class Foo extends React.Component {
  state = {
    count: 0
  }
  handleClick = () => {
    this.setState({count: this.state.count+1})
  }
  callbackFn = () => {
    console.log('在render方法中使用箭头函数')
  }
  render() {
    return (
      <div>
        <button onClick={this.handleClick}>{this.state.count}</button>
        <Child callbackFn={this.callbackFn} />
      </div>
    )
  }
}

export default Foo;

这是类组件的做法,可以把方法写在实例中,如果是函数组件的化那就需要使用 useCallback 处理。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端精髓

小礼物走一走,来CSDN关注我

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值