Optimumkan pertanyaan data untuk React dan React Query hanya berlaku apabila komponen berada dalam viewport
P粉714890053
P粉714890053 2023-08-28 17:26:18
0
1
469

Saya mempunyai halaman yang menggunakan React untuk memaparkan senarai komponen siaran dan untuk setiap komponen siaran saya mendapat ulasan yang berkaitan dengan siaran itu dan memaparkannya di dalam menggunakan perpustakaan React Query. Masalahnya ialah apabila pengguna memuatkan halaman siaran, React Query memuatkan semua ulasan untuk semua siaran sekaligus, yang menyebabkan bahagian belakang saya menjadi perlahan.

Saya mahu melaksanakan mekanisme yang hanya memuatkan ulasan apabila pengguna menatal ke siaran tertentu, bukannya memuatkan semuanya sekali gus apabila halaman dipaparkan. Bagaimana untuk mencapai ini menggunakan React and React Query?

Ini ialah kod sampel semasa saya untuk mendapatkan dan memaparkan ulasan:

Komponen Catatan Saya

import React daripada 'react'; import { useQuery } daripada 'react-query'; const PostComponent = ({ post }) => const {data, isLoading, error } = useQuery( ['komen', post.id], () => fetchComments(post.id) ); kembali ( 
{/* Render komponen siaran anda */} {isLoading &&
Memuatkan ulasan...
} {error &&
Ralat mendapatkan ulasan
} {data &&

{post.title}

)}
); };

Komponen Halaman Catatan Saya

import React daripada 'react'; import { useQuery } daripada 'react-query'; const Halaman Catatan = () => const { data, isLoading, error } = useQuery('posts', fetchPosts); kembali ( 
{isLoading &&
Memuatkan siaran...
} {ralat &&
Ralat mendapatkan siaran
} {data && data.map((post) => ( ))}
); };

P粉714890053
P粉714890053

membalas semua (1)
P粉323224129

Untuk mencapai matlamat ini, anda memerlukan dua komponen.

  1. Intersection Observer API- digunakan untuk menentukan sama ada komponen berada dalam viewport
  2. React Query Dependent Query(bendera didayakan) - Mendayakan penggunaan pertanyaan apabila komponen berada dalam viewport
Untuk memudahkan interaksi dengan Intersection Observer APIdalam apl React anda, anda harus menggunakan API daripada react-intersection-observerIntersection Observer API的交互,您应该使用来自 react-intersection-observer库的 useInViewcangkuk useInViewperpustakaan.
import React from 'react'; import { useQuery } from "react-query"; import { useInView } from "react-intersection-observer"; const PostComponent = ({ post }) => { const { ref, inView } = useInView(); const { data, isLoading, error } = useQuery( ["comments", post.id], () => fetchComments(post.id), // the useQuery hook will fetch only when inView is enabled { enabled: inView } ); return ( 
{isLoading &&
Loading comments...
} {error &&
Error fetching comments
} {data && (

{post.title}

{" "}
)}
); };
    Muat turun terkini
    Lagi>
    kesan web
    Kod sumber laman web
    Bahan laman web
    Templat hujung hadapan
    Tentang kita Penafian Sitemap
    Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!