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

简介: 在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 处理。

相关文章
|
2月前
|
前端开发 开发者
React 函数组件与类组件对比
【10月更文挑战第4天】本文详细比较了React中的函数组件与类组件。函数组件是一种简单的组件形式,以纯函数的形式返回JSX,易于理解与维护,适用于简单的UI逻辑。类组件则是基于ES6类实现的,需要重写`render`方法并能利用更多生命周期方法进行状态管理。文章通过示例代码展示了两者在状态管理与生命周期管理上的差异,并讨论了常见的问题如状态更新异步性与生命周期管理的复杂性,最后给出了相应的解决方法。通过学习,开发者可以根据具体需求选择合适的组件类型。
70 8
|
2月前
|
前端开发
|
2月前
|
Android开发
jmessage-react-plugin的正确引入方法
jmessage-react-plugin的正确引入方法
16 1
|
3月前
|
前端开发 JavaScript 区块链
react18函数组件+antd使用指南-使用代码集合以及报错记录汇总
本文介绍了多个React开发中常见的问题及其解决方案,包括但不限于:1)`useForm`实例未连接到任何`Form`元素的警告及解决方法;2)监听页面滚动事件的实现方式;3)React 18与antd 5.8.6中定制主题的方法;4)React结合antd 4.x版本自定义主题色的步骤;5)解决`ResizeObserver loop`相关报错的技巧;6)处理React设计表单时遇到的CDN资源加载失败问题;7)解决onClick事件传参问题;8)修复类型错误等。每部分均提供详细分析与实用代码示例,帮助开发者快速定位并解决问题。
65 2
|
3月前
|
XML JavaScript 前端开发
学习react基础(1)_虚拟dom、diff算法、函数和class创建组件
本文介绍了React的核心概念,包括虚拟DOM、Diff算法以及如何通过函数和类创建React组件。
36 3
|
3月前
|
前端开发 JavaScript 开发者
请详细介绍React挂载阶段的方法。
请详细介绍React挂载阶段的方法。
63 9
|
3月前
|
前端开发
react学习(22)高阶函数和函数柯里化
react学习(22)高阶函数和函数柯里化
|
4月前
|
前端开发 JavaScript
React 组件生命周期方法详解
【8月更文挑战第30天】
57 5
|
3月前
封装react-antd-table组件参数以及方法如rowSelection、pageNum、pageSize、分页方法等等
文章介绍了如何封装React-Antd的Table组件,包括参数和方法,如行选择(rowSelection)、页码(pageNum)、页面大小(pageSize)、分页方法等,以简化在不同表格组件中的重复代码。
77 0
|
4月前
|
XML 前端开发 JavaScript
React 中render()的用途是什么?
【8月更文挑战第30天】
124 1