iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >ReactQuery渲染优化的方法是什么
  • 673
分享到

ReactQuery渲染优化的方法是什么

2023-07-04 14:07:16 673人浏览 薄情痞子
摘要

这篇文章主要介绍“ReactQuery渲染优化的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ReactQuery渲染优化的方法是什么”文章能帮助大家解决问题。isFetching在之前的

这篇文章主要介绍“ReactQuery渲染优化的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ReactQuery渲染优化的方法是什么”文章能帮助大家解决问题。

isFetching

在之前的例子中我说过,下面这个组件只会在todos的length变化时才会重新渲染,其实我只说了一部分事实:

export const useTodosQuery = (select) =>  useQuery(['todos'], fetchTodos, { select })export const useTodosCount = () => useTodosQuery((data) => data.length)function TodosCount() {  const todosCount = useTodosCount()  return <div>{todosCount.data}</div>}

每次发生后台refetch的时候,这个组件都会下面的数据分别进行一次渲染:

{ status: 'success', data: 2, isFetching: true }{ status: 'success', data: 2, isFetching: false }

这是因为React Query在每个查询中返回了很多基本信息,isFetching就是其中一个。这个属性在请求正在发生的时候会被设置为true。这个在你想要展示一个后台请求的loading标志的时候特别有用。但是如果你不需要,那确实会造成一些不必要的渲染。

notifiOnChange

对于上面说到的这个场景,React Query提供了notifyOnChangeProps参数。他可以在每个场景单独设置来告诉React Query:只在这些属性发生变化的时候再通知我。通过将这个参数设置为['data'],我们可以实现一个新的版本:

export const useTodosQuery = (select, notifyOnChangeProps) =>  useQuery(['todos'], fetchTodos, { select, notifyOnChangeProps })export const useTodosCount = () =>  useTodosQuery((data) => data.length, ['data'])

保持同步

尽管上面的代码可以正常工作,但是它很容易就会造成不同步。如果我们希望针对error进行特殊处理呢?又或者我们需要使用isLoading属性呢?我们不得不确保notifyOnChangeProps属性和我们实际用到的数据保持同步。如果我们忘记将某个数据添加到属性里面,而只监听data属性的变化,当查询返回错误,同时我们也要展示这些错误的时候,我们的组件并不会重新渲染。这个问题当我们把这些属性写死在自定义hook的时候格外明显,因为我们并不知道使用自定义hook的组件实际上会用到哪些数据:

export const useTodosCount = () =>  useTodosQuery((data) => data.length, ['data'])function TodosCount() {  // ???? we are using error, but we are not getting notified if error changes!  const { error, data } = useTodosCount()  return (    <div>      {error ? error : null}      {data ? data : null}    </div>  )}

就像我在文章开头免责声明中说的,我认为这是比偶尔发生的不必要的重新渲染更坏的事情。当然,我们可以传参数给自定义hook,但是这还是需要手动处理,是否有什么方式可以自动处理这个情况呢?请看:

被追踪的查询

这是我感受特别自豪的一个特性,这也是我对这个库第一个重大的贡献。如果你将notifyOnChangeProps设置为'tracked',React Query会跟踪你在渲染过程中用到的数据,会自动计算依赖列表。最终的效果就跟你手动维护这个列表一样,除了你不用再去关注这个问题以外。你也可以全局开启这个特性:

const queryClient = new QueryClient({  defaultOptions: {    queries: {      notifyOnChangeProps: 'tracked',    },  },})function App() {  return (    <QueryClientProvider client={queryClient}>      <Example />    </QueryClientProvider>  )}

利用这个特性,你再也不用考虑重新渲染。当然这个特性也有一些限制,这就是为什么这个特性是一个可选项:

如果你使用对象剩余属性结构的语法的话,最终所有属性都会被追踪。正常的解构语法是没问题的,不要这么做:

// ???? will track all fieldsconst { isLoading, ...queryInfo } = useQuery(...)// ✅ this is totally fineconst { isLoading, data } = useQuery(...)

被追踪的查询只会追踪render过程中用到的数据。如果你只在effects中用到了这些数据,他们并不会被追踪。

const queryInfo = useQuery(...)// ???? will not corectly track dataReact.useEffect(() => {  console.log(queryInfo.data)})// ✅ fine because the dependency array is accessed during renderReact.useEffect(() => {  console.log(queryInfo.data)}, [queryInfo.data])

被追踪的查询不会在每次render的时候被重置,所以只要你使用了一次某个数据,你就会在整个组件的生命周期内追踪这个数据:

const queryInfo = useQuery(...)if (someCondition()) {  // ???? we will track the data field if someCondition was true in any previous render cycle  return <div>{queryInfo.data}</div>}

结构化共享

一个不同的但是并没那么重要的React Query默认开启的渲染优化是结构化共享。这个特性确保数据在所有地方是引用唯一的。举个例子,假设我们有下面这个数据结构

[{ "id": 1, "name": "Learn React", "status": "active" },{ "id": 2, "name": "Learn React Query", "status": "todo" }]

现在假设我们将第一个todo转为done,然后进行了一次后台refetch。我们会从后端拿到一个全新的JSON

{ "id": 1, "name": "Learn React", "status": "active" },{ "id": 1, "name": "Learn React", "status": "done" },{ "id": 2, "name": "Learn React Query", "status": "todo" }]

现在React Query会尝试对比新老状态,尽可能多的复用老的状态。在上面的例子中,todo数据会是一个新的对象,因为我们更新了一个todo。第一个id为1的对象也会是新的对象,但是对于id为2的对象我们会保持跟对应的旧数据一样的引用-React Query会将他复制一份同样的引用到新的数据,因为这部分数据并没有发生变化。

这使得使用selector进行部分订阅变得特别友好:

// ✅ will only re-render if something within todo with id:2 changes// thanks to structural sharinGConst { data } = useTodo(2)

就像我之前提到的,对于selector来说结构化共享会用到两次:一次是在queryFn返回的结果上,另一次是在selector返回的结果上。在一些场景,特别是数据量比较大的场景,结构化共享会成为一个瓶颈。同时它只能使用在jsON可序列化的数据上。如果你不需要这个优化,你可以通过将`structuralSharing`设为false来关闭这个特性。

关于“ReactQuery渲染优化的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: ReactQuery渲染优化的方法是什么

本文链接: https://www.lsjlt.com/news/345621.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ReactQuery渲染优化的方法是什么
    这篇文章主要介绍“ReactQuery渲染优化的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ReactQuery渲染优化的方法是什么”文章能帮助大家解决问题。isFetching在之前的...
    99+
    2023-07-04
  • ReactQuery 渲染优化示例详解
    目录引言isFetchingnotifiOnChange保持同步被追踪的查询结构化共享引言 免责声明:渲染优化是所有应用的进阶话题。React Query已经进行了许多性能优化并且开...
    99+
    2022-11-13
    ReactQuery 渲染优化 ReactQuery 渲染
  • Gallery2数据加载及渲染的方法是什么
    要加载和渲染Gallery2的数据,你可以按照以下步骤进行操作: 连接数据库:Gallery2使用MySQL数据库来存储和管理数...
    99+
    2023-10-23
    Gallery2
  • react请求数据并渲染的方法是什么
    在React中,可以使用fetch或axios等库来发送请求并获取数据。一般情况下,在组件的生命周期方法中发送请求并在获取到数据后进...
    99+
    2023-10-07
    react
  • echarts无法渲染的原因及解决方法是什么
    常见的echarts无法渲染的原因及解决方法如下:原因:1. 引入echarts的路径不正确:可能是路径写错或者文件未正确引入。2....
    99+
    2023-10-08
    echarts
  • 分析vue的渲染是什么
    Vue.js 前端框架在前端开发中,是一个十分流行易用的框架。它的渲染机制是Vue.js的核心机制之一,谈及 Vue.js 渲染也是相当深奥的一部分,它的基本原理和底层机制值得我们去一一剖析和探究。Vue.js 的渲染机制是如何运作的呢?在...
    99+
    2023-05-14
  • Flutter渲染原理是什么
    这篇文章主要介绍了Flutter渲染原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Flutter渲染原理是什么文章都会有所收获,下面我们一起来看看吧。Widget Element RenderObje...
    99+
    2023-07-06
  • CSS前端页面渲染优化属性will-change的使用方法
    这篇文章给大家分享的是有关CSS前端页面渲染优化属性will-change的使用方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言当触发scroll、resize这类的滚动事件时,被触发的频率非常高,间隔也特...
    99+
    2023-06-08
  • Pyecharts可视化图片渲染的方法详解
    使用 pyecharts 渲染成图片一直是开发者比较关心的功能,pyecharts提供了 selenium、phantomjs 和 pyppeteer 三种方式。 更多介绍可以学习官...
    99+
    2024-04-02
  • Vue Nuxt.js 服务器端渲染:实现 SEO 优化的终极方法
    引言 在网站开发的世界中,搜索引擎优化 (SEO) 对于提高网站可见度和吸引有机流量至关重要。而服务器端渲染 (SSR) 已成为 Vue.js 和 Nuxt.js 应用实现 SEO 友好性的关键技术。在这篇文章中,我们将深入探索 Vue ...
    99+
    2024-02-19
    Vue.js Nuxt.js 服务器端渲染 SEO 网站优化
  • react条件渲染指的是什么
    这篇文章主要介绍“react条件渲染指的是什么”,在日常操作中,相信很多人在react条件渲染指的是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react条件渲染指的是...
    99+
    2024-04-02
  • HTML Mashup渲染原理是什么
    这篇文章主要介绍“HTML Mashup渲染原理是什么”,在日常操作中,相信很多人在HTML Mashup渲染原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”HTML Mashup渲染原理是什么”的疑...
    99+
    2023-06-03
  • vue为什么是异步渲染
    本教程操作环境:windows7系统、vue3版,DELL G3电脑。1、nextTick()的原理及作用nextTick确保我们所操作的DOM是更新之后的。(1)应用场景:在视图更新之后,基于新的视图进行操作。在数据变化后执行的某个操作,...
    99+
    2023-05-14
    Vue 异步渲染
  • Hybris CommerceUI tag的渲染逻辑是什么
    这篇文章主要介绍“Hybris CommerceUI tag的渲染逻辑是什么”,在日常操作中,相信很多人在Hybris CommerceUI tag的渲染逻辑是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-06-04
  • ant-design-vue中table自定义格式渲染的方法是什么
    本篇内容介绍了“ant-design-vue中table自定义格式渲染的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ant-de...
    99+
    2023-07-04
  • mini-vue渲染的实现方法
    本篇内容介绍了“mini-vue渲染的实现方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录前言目标 第二步:总结前言目前的主...
    99+
    2023-06-20
  • React首次渲染流程是什么
    本篇内容介绍了“React首次渲染流程是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!题目在开始进行源码分析前,我们先来看几个题目:题目...
    99+
    2023-07-05
  • 提高页面渲染速度:优化回流和重绘的关键方法
    提高页面渲染速度:优化回流和重绘的关键方法,需要具体代码示例 随着网页应用的发展,用户对页面加载速度的要求也越来越高。而页面的渲染速度受到回流和重绘的影响,因此我们需要优化这两个过程来提高页面的渲染速度。本文将介绍一些关键的方法...
    99+
    2024-01-26
    优化 重绘 回流
  • React前端渲染优化--父组件导致子组件重复渲染的问题
    目录React前端渲染优化--父组件导致子组件重复渲染说明一般的优化方式项目中常见会导致重复渲染的写法以及改进方法组件重复渲染问题(pureComponent, React.memo...
    99+
    2022-11-13
    React前端渲染优化 React父组件 React子组件 React重复渲染
  • web前端同构渲染是什么
    这篇文章主要介绍“web前端同构渲染是什么”,在日常操作中,相信很多人在web前端同构渲染是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”web前端同构渲染是什么”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作