返回介绍

memo

发布于 2019-12-27 00:37:38 字数 1340 浏览 1090 评论 0 收藏 0

组件是构成 Rax 中的一个视图单元。这些组件具有状态,此状态是组件的本地状态,当状态值因用户操作而更改时,组件知道何时重新渲染。现在,Rax 组件可以无限重新渲染下去。有些重新渲染可能是必要的,但大多数情况是非必需的,所以这些不必要的渲染将严重拖慢我们的应用程序,降低了性能。

因此我们引入 memo,对应的是函数组件, 如果你的函数组件在给定相同 props 的情况下渲染相同的结果,那么你可以通过将其包装在 memo 中调用,以此通过记忆组件渲染结果的方式来提高组件的性能表现。这意味着在这种情况下,Rax 将跳过渲染组件的操作并直接复用最近一次渲染的结果。

默认情况下其只会对复杂对象做浅层对比,如果你想要控制对比过程,那么请将自定义的比较函数通过第二个参数传入来实现。

示例

这里创建了一个示例,当我们利用 setState 再次 render 时,memo 组件不会再次 render,而正常的组件则会重复 render。

import { memo, useState } from 'rax';
import View from 'rax-view';
import Text from 'rax-text';

const useUpdate = () => {
  const [, setState] = useState(0);
  return () => setState(num => num + 1);
};

const HelloMemo = memo((props) => {
  console.log('memo-render');
  return <Text>{props.children}</Text>
});

const HelloNormal = (props) => {
  console.log('normal-render');
  return <Text>{props.children}</Text>
}

function App() {
  console.log('render')
  const update = useUpdate();
  const [state, setState] = useState(1);
  return <View>
    <HelloNormal>Rax</HelloNormal>
    <HelloMemo>Hello</HelloMemo>
    <View>{state}</View>
    <View onClick={() => setState(num => num + 1)}>Update</View>
  </View>
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文