返回

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

发布时间:2023-10-18 20:56:41 221


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

class Foo extends Component {
handleClick = () => {
console.log('Click happened')
}
render() {
return ;
}
}

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

class Foo extends Component {
render() {
return ;
}
}

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

注意:

在 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 (
todo

)
}
}

class Foo extends React.Component {
state = {
count: 0
}
handleClick = () => {
this.setState({count: this.state.count+1})
}
render() {
return (


{ console.log('在render方法中使用箭头函数') }} />

)
}
}

export default Foo;

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

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

import React from 'react';

class Child extends React.PureComponent {
render () {
console.log('重新渲染')
return (
todo

)
}
}

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




)
}
}

export default Foo;

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


特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
精选文章
thumb 中国研究员首次曝光美国国安局顶级后门—“方程式组织”
thumb 俄乌线上战争,网络攻击弥漫着数字硝烟
thumb 从网络安全角度了解俄罗斯入侵乌克兰的相关事件时间线
下一篇
Vue3不支持eventBus 2023-10-18 18:04:35