{"id":37958,"date":"2023-08-18T02:47:16","date_gmt":"2023-01-20T14:02:22","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/"},"modified":"2024-04-30T18:59:43","modified_gmt":"2024-04-30T10:59:43","slug":"%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/","title":{"rendered":"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller)"},"content":{"rendered":"<h2>\u9996\u5148<\/h2>\n<p>\u8fd9\u662f\u4e0a\u4e00\u6b21\u4f7f\u7528\u7684\u5e93\u7248\u672c\u3002\u8fd9\u662f\u4f7f\u7528 react-query \u548c react-infinite-scroller \u7ed3\u5408\u7684\u5b9e\u73b0\u3002<\/p>\n<p>&nbsp;<\/p>\n<h2>\u4ea7\u51fa<\/h2>\n<p>&nbsp;<\/p>\n<pre class=\"post-pre\"><code>~\/develop\/HITOTSU\/react_infinity_scroll<span class=\"nv\">$ <\/span>tree <span class=\"nt\">-I<\/span> node_modules \r\n<span class=\"nb\">.<\/span>\r\n\u251c\u2500\u2500 README.md\r\n\u251c\u2500\u2500 package.json\r\n\u251c\u2500\u2500 public\r\n\u2502   \u251c\u2500\u2500 favicon.ico\r\n\u2502   \u251c\u2500\u2500 index.html\r\n\u2502   \u251c\u2500\u2500 logo192.png\r\n\u2502   \u251c\u2500\u2500 logo512.png\r\n\u2502   \u251c\u2500\u2500 manifest.json\r\n\u2502   \u2514\u2500\u2500 robots.txt\r\n\u251c\u2500\u2500 src\r\n\u2502   \u251c\u2500\u2500 App.tsx\r\n\u2502   \u251c\u2500\u2500 components\r\n\u2502   \u2502   \u251c\u2500\u2500 ReactQueryInfiteScrollSample.tsx\r\n\u2502   \u2502   \u2514\u2500\u2500 UseInfiniteScrollSample.tsx\r\n\u2502   \u251c\u2500\u2500 hooks\r\n\u2502   \u2502   \u2514\u2500\u2500 useInfiniteScroll.tsx\r\n\u2502   \u251c\u2500\u2500 index.tsx\r\n\u2502   \u251c\u2500\u2500 logo.svg\r\n\u2502   \u2514\u2500\u2500 type.ts\r\n\u251c\u2500\u2500 tsconfig.json\r\n\u2514\u2500\u2500 yarn.lock\r\n\r\n5 directories, 17 files\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">React<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">ReactDOM<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react-dom\/client<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">App<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/App<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">QueryClient<\/span><span class=\"p\">,<\/span> <span class=\"nx\">QueryClientProvider<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react-query<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">root<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">ReactDOM<\/span><span class=\"p\">.<\/span><span class=\"nf\">createRoot<\/span><span class=\"p\">(<\/span>\r\n  <span class=\"nb\">document<\/span><span class=\"p\">.<\/span><span class=\"nf\">getElementById<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">root<\/span><span class=\"dl\">'<\/span><span class=\"p\">)<\/span> <span class=\"k\">as<\/span> <span class=\"nx\">HTMLElement<\/span>\r\n<span class=\"p\">);<\/span>\r\n<span class=\"kd\">const<\/span> <span class=\"nx\">queryClient<\/span> <span class=\"o\">=<\/span> <span class=\"k\">new<\/span> <span class=\"nc\">QueryClient<\/span><span class=\"p\">();<\/span>\r\n\r\n<span class=\"nx\">root<\/span><span class=\"p\">.<\/span><span class=\"nf\">render<\/span><span class=\"p\">(<\/span>\r\n  <span class=\"p\">&lt;<\/span><span class=\"nc\">React<\/span><span class=\"p\">.<\/span><span class=\"nc\">StrictMode<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nc\">QueryClientProvider<\/span> <span class=\"na\">client<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">queryClient<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nc\">App<\/span> <span class=\"p\">\/&gt;<\/span>\r\n    <span class=\"p\">&lt;\/<\/span><span class=\"nc\">QueryClientProvider<\/span><span class=\"p\">&gt;<\/span>\r\n  <span class=\"p\">&lt;\/<\/span><span class=\"nc\">React<\/span><span class=\"p\">.<\/span><span class=\"nc\">StrictMode<\/span><span class=\"p\">&gt;<\/span>\r\n<span class=\"p\">);<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"nx\">React<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span> <span class=\"nx\">UseInfiniteScrollSample<\/span> <span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">.\/components\/UseInfiniteScrollSample<\/span><span class=\"dl\">'<\/span>\r\n\r\n<span class=\"kd\">function<\/span> <span class=\"nf\">App<\/span><span class=\"p\">()<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"k\">return <\/span><span class=\"p\">(<\/span>\r\n    <span class=\"p\">&lt;<\/span><span class=\"nc\">UseInfiniteScrollSample<\/span> <span class=\"p\">\/&gt;<\/span>\r\n  <span class=\"p\">);<\/span>\r\n<span class=\"p\">}<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"k\">default<\/span> <span class=\"nx\">App<\/span><span class=\"p\">;<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">FC<\/span><span class=\"p\">,<\/span> <span class=\"nx\">useRef<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">InfiniteScroll<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react-infinite-scroller<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">React<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"nx\">axios<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">axios<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n<span class=\"k\">import<\/span> <span class=\"p\">{<\/span><span class=\"nx\">useInfiniteQuery<\/span><span class=\"p\">}<\/span> <span class=\"k\">from<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">react-query<\/span><span class=\"dl\">'<\/span><span class=\"p\">;<\/span>\r\n\r\n<span class=\"k\">export<\/span> <span class=\"kd\">const<\/span> <span class=\"nx\">ReactQueryInfiteScrollSample<\/span><span class=\"p\">:<\/span> <span class=\"nx\">FC<\/span> <span class=\"o\">=<\/span> <span class=\"p\">()<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">containerRef<\/span> <span class=\"o\">=<\/span> <span class=\"nf\">useRef<\/span><span class=\"p\">(<\/span><span class=\"kc\">null<\/span><span class=\"p\">);<\/span>\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">LIMIT<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">10<\/span><span class=\"p\">;<\/span>\r\n\r\n  <span class=\"kd\">const<\/span> <span class=\"nx\">fetchData<\/span> <span class=\"o\">=<\/span> <span class=\"k\">async <\/span><span class=\"p\">(<\/span><span class=\"na\">page<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n    <span class=\"nx\">console<\/span><span class=\"p\">.<\/span><span class=\"nf\">log<\/span><span class=\"p\">(<\/span><span class=\"dl\">'<\/span><span class=\"s1\">fetchData call page<\/span><span class=\"dl\">'<\/span><span class=\"p\">,<\/span> <span class=\"nx\">page<\/span><span class=\"p\">);<\/span>\r\n    <span class=\"kd\">const<\/span> <span class=\"nx\">response<\/span> <span class=\"o\">=<\/span> <span class=\"k\">await<\/span> <span class=\"nx\">axios<\/span><span class=\"p\">.<\/span><span class=\"kd\">get<\/span><span class=\"p\">&lt;<\/span><span class=\"nc\">Post<\/span><span class=\"err\">[]<\/span><span class=\"p\">&gt;<\/span>(`https:\/\/jsonplaceholder.typicode.com\/posts?_page=$<span class=\"si\">{<\/span><span class=\"nx\">page<\/span><span class=\"si\">}<\/span>`);\r\n    const data = response.data;\r\n    return data;\r\n  };\r\n\r\n  const <span class=\"si\">{<\/span><span class=\"nx\">data<\/span><span class=\"p\">,<\/span> <span class=\"nx\">isLoading<\/span><span class=\"p\">,<\/span> <span class=\"nx\">isFetching<\/span><span class=\"p\">,<\/span> <span class=\"nx\">hasNextPage<\/span><span class=\"p\">,<\/span> <span class=\"nx\">fetchNextPage<\/span><span class=\"si\">}<\/span> = useInfiniteQuery(\r\n    'todos',\r\n    (<span class=\"si\">{<\/span><span class=\"nx\">pageParam<\/span> <span class=\"o\">=<\/span> <span class=\"mi\">1<\/span><span class=\"si\">}<\/span>) =&gt; fetchData(pageParam),\r\n    <span class=\"si\">{<\/span>\r\n      <span class=\"nx\">getNextPageParam<\/span><span class=\"p\">:<\/span> <span class=\"p\">(<\/span><span class=\"nx\">lastPage<\/span><span class=\"p\">,<\/span> <span class=\"nx\">allPages<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">{<\/span>\r\n        <span class=\"kd\">const<\/span> <span class=\"nx\">nextPage<\/span> <span class=\"o\">=<\/span> <span class=\"nx\">lastPage<\/span><span class=\"p\">.<\/span><span class=\"nx\">length<\/span> <span class=\"o\">===<\/span> <span class=\"nx\">LIMIT<\/span> <span class=\"p\">?<\/span> <span class=\"nx\">allPages<\/span><span class=\"p\">.<\/span><span class=\"nx\">length<\/span> <span class=\"o\">+<\/span> <span class=\"mi\">1<\/span> <span class=\"p\">:<\/span> <span class=\"kc\">undefined<\/span><span class=\"p\">;<\/span>\r\n        <span class=\"k\">return<\/span> <span class=\"nx\">nextPage<\/span><span class=\"p\">;<\/span>\r\n      <span class=\"p\">},<\/span>\r\n    <span class=\"si\">}<\/span>\r\n  );\r\n\r\n  if (isLoading) return <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"p\">\/&gt;<\/span>;\r\n\r\n  return (\r\n    <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">style<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">{<\/span><span class=\"na\">height<\/span><span class=\"p\">:<\/span> <span class=\"dl\">'<\/span><span class=\"s1\">2000px<\/span><span class=\"dl\">'<\/span><span class=\"p\">}<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\u7121\u9650\u30b9\u30af\u30ed\u30fc\u30eb<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"si\">{<\/span><span class=\"nx\">isFetching<\/span> <span class=\"o\">&amp;&amp;<\/span> <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">className<\/span><span class=\"p\">=<\/span><span class=\"s\">\"loading\"<\/span><span class=\"p\">&gt;<\/span>Loading...<span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span><span class=\"si\">}<\/span>\r\n      <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">ref<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">containerRef<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n        <span class=\"p\">&lt;<\/span><span class=\"nc\">InfiniteScroll<\/span> <span class=\"na\">loadMore<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"p\">(<\/span><span class=\"nx\">page<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"nf\">fetchNextPage<\/span><span class=\"p\">({<\/span><span class=\"na\">pageParam<\/span><span class=\"p\">:<\/span> <span class=\"nx\">page<\/span><span class=\"p\">})<\/span><span class=\"si\">}<\/span> <span class=\"na\">hasMore<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">hasNextPage<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n          <span class=\"si\">{<\/span><span class=\"nx\">data<\/span><span class=\"p\">?.<\/span><span class=\"nx\">pages<\/span><span class=\"p\">.<\/span><span class=\"nf\">map<\/span><span class=\"p\">((<\/span><span class=\"nx\">page<\/span><span class=\"p\">,<\/span> <span class=\"nx\">i<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">(<\/span>\r\n            <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">key<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">i<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n              <span class=\"si\">{<\/span><span class=\"nx\">page<\/span><span class=\"p\">.<\/span><span class=\"nf\">map<\/span><span class=\"p\">((<\/span><span class=\"nx\">item<\/span><span class=\"p\">:<\/span> <span class=\"nx\">Post<\/span><span class=\"p\">)<\/span> <span class=\"o\">=&gt;<\/span> <span class=\"p\">(<\/span>\r\n                <span class=\"p\">&lt;<\/span><span class=\"nt\">div<\/span> <span class=\"na\">key<\/span><span class=\"p\">=<\/span><span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"si\">}<\/span><span class=\"p\">&gt;<\/span>\r\n                  <span class=\"p\">&lt;<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>\r\n                    <span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">id<\/span><span class=\"si\">}<\/span>\uff1a<span class=\"si\">{<\/span><span class=\"nx\">item<\/span><span class=\"p\">.<\/span><span class=\"nx\">title<\/span><span class=\"si\">}<\/span>\r\n                  <span class=\"p\">&lt;\/<\/span><span class=\"nt\">p<\/span><span class=\"p\">&gt;<\/span>\r\n                <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n              <span class=\"p\">))<\/span><span class=\"si\">}<\/span>\r\n            <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n          <span class=\"p\">))<\/span><span class=\"si\">}<\/span>\r\n        <span class=\"p\">&lt;\/<\/span><span class=\"nc\">InfiniteScroll<\/span><span class=\"p\">&gt;<\/span>\r\n      <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n    <span class=\"p\">&lt;\/<\/span><span class=\"nt\">div<\/span><span class=\"p\">&gt;<\/span>\r\n  );\r\n};\r\n\r\ninterface Post <span class=\"si\">{<\/span>\r\n  <span class=\"nx\">userId<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">id<\/span><span class=\"p\">:<\/span> <span class=\"kr\">number<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">title<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n  <span class=\"nl\">body<\/span><span class=\"p\">:<\/span> <span class=\"kr\">string<\/span><span class=\"p\">;<\/span>\r\n<span class=\"si\">}<\/span>\r\n\r\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u9996\u5148 \u8fd9\u662f\u4e0a\u4e00\u6b21\u4f7f\u7528\u7684\u5e93\u7248\u672c\u3002\u8fd9\u662f\u4f7f\u7528 react-query \u548c react-infinite-scroll [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-37958","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller) - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002handson\u3001react-query\u3001react-infinite-scroller\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller)\" \/>\n<meta property=\"og:description\" content=\"\u9996\u5148 \u8fd9\u662f\u4e0a\u4e00\u6b21\u4f7f\u7528\u7684\u5e93\u7248\u672c\u3002\u8fd9\u662f\u4f7f\u7528 react-query \u548c react-infinite-scroll [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002handson\u3001react-query\u3001react-infinite-scroller\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-01-20T14:02:22+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-30T10:59:43+00:00\" \/>\n<meta name=\"author\" content=\"\u97f5, \u79d1\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u97f5, \u79d1\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/\",\"name\":\"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller) - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-01-20T14:02:22+00:00\",\"dateModified\":\"2024-04-30T10:59:43+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/6530331a63adef3b3443a1fab53a0e6e\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller)\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/6530331a63adef3b3443a1fab53a0e6e\",\"name\":\"\u97f5, \u79d1\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/429ccb39b3fff5188bc17986222cfb0936cbadb8cc933cff04ab5ca01bd30a08?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/429ccb39b3fff5188bc17986222cfb0936cbadb8cc933cff04ab5ca01bd30a08?s=96&d=mm&r=g\",\"caption\":\"\u97f5, \u79d1\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunke\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller) - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002handson\u3001react-query\u3001react-infinite-scroller\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller)","og_description":"\u9996\u5148 \u8fd9\u662f\u4e0a\u4e00\u6b21\u4f7f\u7528\u7684\u5e93\u7248\u672c\u3002\u8fd9\u662f\u4f7f\u7528 react-query \u548c react-infinite-scroll [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528react\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002handson\u3001react-query\u3001react-infinite-scroller\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-01-20T14:02:22+00:00","article_modified_time":"2024-04-30T10:59:43+00:00","author":"\u97f5, \u79d1","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u97f5, \u79d1","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"2 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/","name":"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller) - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-01-20T14:02:22+00:00","dateModified":"2024-04-30T10:59:43+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/6530331a63adef3b3443a1fab53a0e6e"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528React\u6765\u5b9e\u73b0\u65e0\u9650\u6eda\u52a8\u3002(Handson\u3001react-query\u3001react-infinite-scroller)"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/6530331a63adef3b3443a1fab53a0e6e","name":"\u97f5, \u79d1","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/429ccb39b3fff5188bc17986222cfb0936cbadb8cc933cff04ab5ca01bd30a08?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/429ccb39b3fff5188bc17986222cfb0936cbadb8cc933cff04ab5ca01bd30a08?s=96&d=mm&r=g","caption":"\u97f5, \u79d1"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/yunke\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8react%e6%9d%a5%e5%ae%9e%e7%8e%b0%e6%97%a0%e9%99%90%e6%bb%9a%e5%8a%a8%e3%80%82handson%e3%80%81react-query%e3%80%81react-infinite-scroller\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/37958","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=37958"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/37958\/revisions"}],"predecessor-version":[{"id":93705,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/37958\/revisions\/93705"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=37958"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=37958"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=37958"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}