react 性能优化之:react.memo 有效阻止父组件更新带来的子组件也重新渲染的问题。

前言:

如果父组件的state发生变化,那么就需要重新render。其下的子组件即使没有用到此state,也会跟着重新render。性能受影响。
现有方法 react.memo 能实现,只有当子组件的 props里的数据发生变化后,才会重新render。

注: react.memo 此方法是浅比较。

父组件

父组件的input框输入的时候,会引起 inp_value 的变化。必然引起父组件的重新render。但是此时并没有引起子组件的render

案例中,我使用了usecallback,第二个参数传递空数组,生成了一个不会随着任何state变化而变化的函数 fa_callback ,此函数传递给子组件。
同理test_value一个当父组件更新时不会变化的普通state,传递给子组件。


export default function Reactuse() {
	const [inp_value, setinp_value] = useState('123');
    const [test_value, settest_value] = useState('456');

// 这个函数没有依赖项,不会被更新。即使此组件重新渲染
	const fa_callback = useCallback(() => {
		console.log('父组件的useCallback函数 ------------ ');
	}, []);
		useEffect(() => {
		console.log(inp_value, 'inp_value变了');
	}, [inp_value]);
	return (
		<div>
		   <input
				type="text"
				value={inp_value}
				onChange={(e) => {
					setinp_value(e.target.value);
				}}
			/>
			//一个不会发生变化的函数fa_callback       和      一个未变化的 数据test_value
			<Test3 fa_callback={fa_callback}  test_value ={test_value}/>
		</div>
	);
}

子组件
import React, { useState, useEffect } from 'react';
import eventEmmiter from '../config/tools';

function Test3(props) {
//下面这句执行就说明,子组件重新渲染了
	console.log('组件3  didupdata -----------');

	useEffect(() => {
		console.log('组件3  didmount -----------');
	}, []);
	return (
		<div style={{ backgroundColor: 'pink', width: '300px', height: '200px' }}>
			子组件3 !!!
			<button
				onClick={() => {
					props.fa_callback();
				}}
			>
				点击执行父组件的方法
			</button>
		</div>
	);
}
//下面是重点!!!
export default React.memo(Test3);

如图我在输入框里输入文字,inp_value变化了,但是组件3并没有重新render

在这里插入图片描述
下图是没使用 memo的情况

React.memo的第二个参数!
function MyComponent(props) {
  /* 使用 props 渲染 */
}
function areEqual(prevProps, nextProps) {
  /*
  如果把 nextProps 传入 render 方法的返回结果与
  将 prevProps 传入 render 方法的返回结果一致则返回 true,
  否则返回 false
  */
}
export default React.memo(MyComponent, areEqual);

总结

借用大佬的话

useCallback 是要配合子组件的 shouldComponentUpdate 或者 React.memo一起来使用的,否则就是反向优化。

至于为啥是反向优化参考下面这句话:

const f = () => {};,它实际上和useCallback(() => {}, []) 是一个概念,都创建了一个函数,useCallback方法接收的参数就是函数,他既然都能调用传递进去肯定就是这个函数已经被创建了的,创建一个函数所带来的性能消耗很小;useCallback 的作用就是缓存函数,(并比较依赖项),把之前的那个函数也留着,如果依赖项没变就返回之前缓存的那个函数,如果依赖项变了就返回最新的这个函数。因此,比较和缓存的过程也是耗费性能的,因此不建议单独使用这个useCallback

参考文献

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果你想要在组件中控制子组件的渲染,可以使用 React 的条件渲染功能,即根据某个条件来决定是否渲染子组件。 以下是一个示例代码: ```jsx import React, { useState } from 'react'; function ParentComponent() { const [shouldRenderChild, setShouldRenderChild] = useState(true); function handleButtonClick() { // 点击按钮时,切换 shouldRenderChild 的值 setShouldRenderChild(!shouldRenderChild); } return ( <div> <button onClick={handleButtonClick}>Toggle child component</button> {shouldRenderChild && <ChildComponent />} </div> ); } function ChildComponent() { return <div>Child component</div>; } ``` 在上面的示例中,`ParentComponent` 组件中定义了一个名为 `shouldRenderChild` 的状态变量,初始值为 `true`,表示要渲染子组件。在 `ParentComponent` 组件中,可以在需要渲染子组件的地方使用条件渲染来控制子组件的渲染。在上面的代码中,我们使用了 `shouldRenderChild && <ChildComponent />` 的语法来实现子组件的条件渲染,当 `shouldRenderChild` 为 `true` 时,渲染 `ChildComponent` 组件,否则不渲染。 在 `handleButtonClick` 函数中,调用 `setShouldRenderChild` 来切换 `shouldRenderChild` 的值,从而实现在组件阻止子组件的渲染。 需要注意的是,在使用条件渲染时,如果要渲染子组件比较复杂,可以将子组件的渲染逻辑单独提取到一个函数中,以提高代码的可读性和可维护性。 ### 回答2: 在 React 中,组件主要通过向子组件传递 props 来控制子组件的渲染。如果我们希望在组件阻止子组件的渲染,有几种方法可以实现。 一种简单的方法是通过在组件的 render 方法中根据一定的条件来控制下一级子组件的渲染。比如,我们可以在组件中定义一个变量,根据这个变量的值动态决定是否渲染子组件。示例如下: ```javascript class ParentComponent extends React.Component { render() { const shouldRenderChild = false; // 根据条件决定是否渲染子组件 return ( <div> {shouldRenderChild && <ChildComponent />} // 根据条件渲染子组件 </div> ); } } ``` 在上面的示例中,如果 shouldRenderChild 的值为 true,那么子组件 ChildComponent 就渲染组件中,否则不渲染。 另一种方法是使用 React 的生命周期方法 shouldComponentUpdate。我们可以在组件中重写这个方法,在其中根据一定的条件返回 true 或 false,来决定子组件是否需要重新渲染。示例如下: ```javascript class ParentComponent extends React.Component { shouldComponentUpdate(nextProps, nextState) { const shouldRenderChild = false; // 根据条件决定是否渲染子组件 return shouldRenderChild; // 返回 true 或 false } render() { return ( <div> <ChildComponent /> </div> ); } } ``` 在这种情况下,如果 shouldRenderChild 的值为 true,则子组件 ChildComponent 重新渲染;如果值为 false,则子组件不重新渲染。 总结来说,组件可以通过在 render 方法中根据条件决定是否渲染子组件,或者重写 shouldComponentUpdate 方法来控制子组件的渲染。这些方法可以根据具体的业务需求来选择合适的方来实现。 ### 回答3: 在React中,如果希望在函数组件阻止子组渲染,可以使用React的shouldComponentUpdate()方法或者Reactmemo()函数来实现。 对于使用class组件函数组件,可以重写shouldComponentUpdate()方法,该方法决定了组件在是否需要重新渲染。在shouldComponentUpdate()方法中,可以通过判断组件的某个状态或属性是否发生变化,来决定是否进行重新渲染。如果需要阻止子组渲染,可以在shouldComponentUpdate()返回false。这样,子组件就不因为组件更新重新渲染。 对于使用函数组件函数组件,可以使用Reactmemo()函数来包裹子组件。memo()函数是一个高阶组件,能够阻止子组件的不必要的重新渲染。当以memo()包裹的子组件的props没有变化时,子组件就不重新渲染。 无论是使用shouldComponentUpdate()方法还是memo()函数,都需要谨慎使用,以免过多的阻止组件重新渲染带来性能问题。只有在确实需要减少不必要的重新渲染时,才应该使用这些方法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值