日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

React Query 的 useQuery 竟也內(nèi)置了分頁查詢支持!

來源: 責編: 時間:2024-06-27 17:19:16 221觀看
導讀本次我們將繼續(xù) useQuery() API 的學習,著重講述 useQuery() 在分頁上的優(yōu)化能力[3]。基本分頁功能實現(xiàn)項目中通常會遇到分頁查詢的需要,通過之前的學習,我們會寫出這樣的代碼。function Example() { const [page, setP

本次我們將繼續(xù) useQuery() API 的學習,著重講述 useQuery() 在分頁上的優(yōu)化能力[3]。QmD28資訊網(wǎng)——每日最新資訊28at.com

基本分頁功能實現(xiàn)

項目中通常會遇到分頁查詢的需要,通過之前的學習,我們會寫出這樣的代碼。QmD28資訊網(wǎng)——每日最新資訊28at.com

function Example() {  const [page, setPage] = useState(1)  const { isLoading, isError, error, data: posts } = useQuery(    ['posts', page],    () => axios.get('https://jsonplaceholder.typicode.com/posts', { params: { _page: page, _limit: 6 } })  )  return (    <div>      <h2>Posts(第{page}頁)</h2>      {        isLoading && <p>Loading....</p>      }      {        isError && <p>An error has occurred: {error.message}</p>      }      <ul>        {          posts?.data.map(post => (            <li key={post.id}>{post.title}</li>          ))        }      </ul>      <div style={{ display: 'flex', gap: '8px' }}>        <button disabled={isLoading} onClick={() => setPage(prePage => Math.max(0, prePage - 1))}>Previous Page</button>        <button disabled={isLoading} onClick={() => setPage(prePage => prePage + 1)}>Next Page</button>      </div>    </div>  )}

瀏覽器訪問:QmD28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片QmD28資訊網(wǎng)——每日最新資訊28at.com

點擊“Next Page”查看下一頁數(shù)據(jù)。QmD28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片QmD28資訊網(wǎng)——每日最新資訊28at.com

確實也實現(xiàn)了功能,不過體驗上不好的地方在于,每次切換到新一頁數(shù)據(jù)時,中間會間隔一個“Loading...”效果,導致頁面閃動。QmD28資訊網(wǎng)——每日最新資訊28at.com

為了不然頁面閃動,我們可以考慮在加載新頁面數(shù)據(jù)時,同時保留舊數(shù)據(jù)的展示不就行了嗎?后面一旦新數(shù)據(jù)到了,直接替換就行。QmD28資訊網(wǎng)——每日最新資訊28at.com

useQuery() API 可考慮到了這方面的使用體驗,于是便提供了一個 keepPreviousData 選項。QmD28資訊網(wǎng)——每日最新資訊28at.com

保留舊數(shù)據(jù)的分頁功能

我們在之前案例的基礎之上,調(diào)用 useQuery() 時,指定 keepPreviousData: true 選項。QmD28資訊網(wǎng)——每日最新資訊28at.com

const { isLoading, isError, error, data: posts } = useQuery(  ['posts', page],  () => axios.get('https://jsonplaceholder.typicode.com/posts', { params: { _page: page, _limit: 6 } }),  {    keepPreviousData: true  })

刷新頁面,再來看看加載新頁的效果。QmD28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片QmD28資訊網(wǎng)——每日最新資訊28at.com

發(fā)現(xiàn)頁面不再閃動了。QmD28資訊網(wǎng)——每日最新資訊28at.com

不過,這種狀態(tài)下的中間狀態(tài)我們還要細致的控制一下,比如請求過程中禁用按鈕的點擊能力。QmD28資訊網(wǎng)——每日最新資訊28at.com

- const { isLoading, isError, error, data: posts } = useQuery()+ const { isLoading, isError, isFetching, error, data: posts } = useQuery()<div style={{ display: 'flex', gap: '8px' }}>-  <button disabled={isLoading} notallow={() => setPage(prePage => Math.max(0, prePage - 1))}>Previous Page</button>-  <button disabled={isLoading} notallow={() => setPage(prePage => prePage + 1)}>Next Page</button>+  <button disabled={isLoading || isFetching} notallow={() => setPage(prePage => Math.max(0, prePage - 1))}>Previous Page</button>+  <button disabled={isLoading || isFetching} notallow={() => setPage(prePage => prePage + 1)}>Next Page</button></div>

再次查看效果:QmD28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片QmD28資訊網(wǎng)——每日最新資訊28at.com

不過,除了 isFetching,useQuery() 還返回了一個 isPreviousData 狀態(tài),讓你判斷當前展示的是不是舊數(shù)據(jù)。QmD28資訊網(wǎng)——每日最新資訊28at.com

- const { isLoading, isError, isFetching, error, data: posts } = useQuery()+ const { isLoading, isError, isPreviousData, isFetching, error, data: posts } = useQuery()- <ul>+ <ul style={{ opacity: isPreviousData ? 0.5 : 1 }}>  {    posts?.data.map(post => (      <li key={post.id}>{post.title}</li>    ))  }</ul>

再次查看效果:QmD28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片QmD28資訊網(wǎng)——每日最新資訊28at.com

這樣舊數(shù)據(jù)在展示期間,加了一點點透明效果。QmD28資訊網(wǎng)——每日最新資訊28at.com

至此,我們就講完了 useQuery() 的分頁優(yōu)化能力。QmD28資訊網(wǎng)——每日最新資訊28at.com

總結

本文我講解了另一個 useQuery() 能力——keepPreviousData。QmD28資訊網(wǎng)——每日最新資訊28at.com

在設置 keepPreviousData: true 后,我們在進行分頁查詢時,同時能保持舊數(shù)據(jù)的展示,避免頁面閃動。QmD28資訊網(wǎng)——每日最新資訊28at.com

本質(zhì)上,keepPreviousData 選項是 useQuery() 針對分頁場景上的一個優(yōu)化能力。QmD28資訊網(wǎng)——每日最新資訊28at.com

當然,UI 交互中還有一種特殊的分頁場景,即無限查詢(Infinite Query)。這在“上滑/上拉查看歷史數(shù)據(jù)”,或者“下滑/下拉查看最新數(shù)據(jù)”被廣泛采用,不過 useQuery 是解決不了的了,這要靠 useInfiniteQuery()。QmD28資訊網(wǎng)——每日最新資訊28at.com

參考資料

[1]React Query 是做什么的?: https://juejin.cn/post/7378015213348257855QmD28資訊網(wǎng)——每日最新資訊28at.com

[2]一個數(shù)據(jù)獲竟然被 React Query 玩出這么多花樣來!: https://juejin.cn/post/7380342160581918731QmD28資訊網(wǎng)——每日最新資訊28at.com

[3]useQuery() 在分頁上的優(yōu)化能力: https://tanstack.com/query/v3/docs/framework/react/guides/paginated-queriesQmD28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-96988-0.htmlReact Query 的 useQuery 竟也內(nèi)置了分頁查詢支持!

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 用 foreach 風格遍歷的八個高效 Python 技巧

下一篇: vivo 互聯(lián)網(wǎng)自研代碼評審 VCR 落地實踐

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
亚洲欧洲av一区二区三区久久| 国产精品理论片在线观看| 欧美一区二区三区精品| 久久国产精品久久w女人spa| 久久夜色撩人精品| 欧美精品午夜| 国产欧美另类| 亚洲国产精品久久久久秋霞不卡 | 午夜日韩视频| 久久免费少妇高潮久久精品99| 欧美a级一区二区| 国产精品久久97| 一色屋精品视频在线观看网站| 日韩午夜电影在线观看| 香蕉免费一区二区三区在线观看| 久久九九全国免费精品观看| 欧美日韩播放| 国产一区二区三区黄| 亚洲精品国产精品国自产观看| 亚洲欧美日韩一区二区三区在线| 美脚丝袜一区二区三区在线观看 | 亚洲精一区二区三区| 亚洲男女自偷自拍图片另类| 老司机免费视频一区二区三区| 欧美午夜激情视频| 在线观看亚洲一区| 亚洲欧美美女| 欧美激情一二三区| 国产手机视频一区二区| 99精品福利视频| 久久久久久九九九九| 欧美午夜视频| 亚洲日本中文| 久久久97精品| 国产精品久久久久久久久久久久久久 | 久久国产欧美| 国产精品成人v| 最新日韩在线视频| 久久九九免费| 国产精品素人视频| 99精品视频免费观看视频| 久久午夜影视| 国产乱码精品一区二区三| 亚洲免费观看高清完整版在线观看| 新片速递亚洲合集欧美合集| 欧美日韩在线不卡一区| 亚洲韩国一区二区三区| 久久电影一区| 国产精品视频1区| 日韩视频免费观看高清完整版| 久久手机免费观看| 国产精品综合| 亚洲调教视频在线观看| 欧美乱人伦中文字幕在线| **欧美日韩vr在线| 久久av二区| 国产欧美日韩综合精品二区| 亚洲欧美另类久久久精品2019| 欧美午夜三级| 一区二区三区三区在线| 欧美巨乳在线观看| 亚洲精品1区| 嫩草国产精品入口| 在线观看一区视频| 久久久久久亚洲精品中文字幕| 国产午夜精品视频免费不卡69堂| 亚洲欧美日韩区| 国产精品久久777777毛茸茸| 一区二区成人精品| 欧美日韩国产精品一卡| 日韩午夜剧场| 欧美国产三区| 亚洲精品欧美在线| 欧美国产日韩免费| 91久久久久久久久久久久久| 欧美成人国产一区二区| 亚洲国产日本| 欧美精品久久久久久久免费观看| 亚洲国产欧美一区二区三区同亚洲| 久热国产精品| 亚洲国产精品国自产拍av秋霞| 免费视频一区| 91久久久久久| 欧美人与禽猛交乱配| 亚洲免费激情| 欧美午夜精彩| 午夜一级久久| 很黄很黄激情成人| 久久综合久久综合这里只有精品| 在线观看免费视频综合| 欧美成人免费在线视频| 亚洲欧洲日产国产综合网| 欧美激情2020午夜免费观看| 日韩午夜激情电影| 欧美午夜激情视频| 午夜精品美女久久久久av福利| 国产日韩精品一区二区三区在线| 久久精品成人一区二区三区| 激情国产一区| 欧美激情片在线观看| 一本色道**综合亚洲精品蜜桃冫| 国产精品成人一区| 欧美影院视频| 亚洲二区视频在线| 欧美日韩高清在线一区| 亚洲综合国产精品| 国产一区二区中文| 麻豆freexxxx性91精品| 日韩视频免费观看高清在线视频| 国产精品美女在线| 久久久女女女女999久久| 亚洲激情六月丁香| 欧美性事在线| 久久久久成人精品| 亚洲精品国精品久久99热一| 国产精品福利网| 久久―日本道色综合久久| 亚洲精品国产精品乱码不99| 国产精品久久久久久av福利软件| 久久精精品视频| 亚洲人久久久| 国产精品中文在线| 免费久久99精品国产自| 亚洲调教视频在线观看| 韩国欧美一区| 国产一区二区三区丝袜| 欧美日韩亚洲国产精品| 中文国产成人精品| 99视频精品免费观看| 欧美在线亚洲一区| 亚洲国产高清一区二区三区| 欧美日本免费| 欧美一级免费视频| 亚洲欧洲精品一区二区三区不卡| 欧美午夜精品伦理| 久久免费视频网站| 亚洲一区二区三区在线看| 激情综合色综合久久| 欧美日韩中文另类| 久久免费国产精品| 亚洲宅男天堂在线观看无病毒| 精品av久久久久电影| 欧美午夜视频网站| 噜噜噜久久亚洲精品国产品小说| 在线视频一区观看| 尤物网精品视频| 国产精品任我爽爆在线播放| 欧美成人精品1314www| 小处雏高清一区二区三区| 亚洲区一区二区三区| 国产亚洲制服色| 欧美性猛交xxxx乱大交退制版| 老司机午夜精品视频| 午夜精品久久久久久久久久久久| 亚洲老司机av| 尤物yw午夜国产精品视频| 欧美午夜视频在线| 免费在线亚洲欧美| 久久xxxx精品视频| 亚洲综合日韩在线| 999在线观看精品免费不卡网站| 黄色一区二区在线| 国产精品永久免费| 欧美三级电影大全| 欧美成人三级在线| 久久午夜视频| 欧美中文字幕视频在线观看| 亚洲手机视频| 一级日韩一区在线观看| 亚洲欧洲午夜| 在线观看一区二区视频| 国产偷国产偷亚洲高清97cao| 欧美日韩一区在线播放| 欧美精品手机在线| 蜜臀av一级做a爰片久久| 久久精彩免费视频| 性欧美在线看片a免费观看| 亚洲深夜福利网站| 亚洲最新在线| 亚洲精品日韩久久| 亚洲黄色毛片| 亚洲高清不卡av| 在线精品福利| 怡红院av一区二区三区| 国产在线精品一区二区夜色| 国产精品一区毛片| 国产精品欧美日韩一区二区| 欧美午夜电影完整版| 欧美日韩综合在线| 欧美日韩一区二区免费在线观看| 欧美激情视频在线播放| 欧美电影在线免费观看网站| 免费成人av在线看| 美女主播精品视频一二三四| 乱中年女人伦av一区二区| 美女图片一区二区| 免费精品视频| 欧美成人黄色小视频| 欧美高清在线观看| 欧美精品在线极品| 欧美日韩午夜在线视频| 欧美性色aⅴ视频一区日韩精品| 欧美亚洲第一区| 国产精品久久久久久久免费软件|