React.js adalah salah satu library JavaScript paling populer untuk membangun antarmuka pengguna (UI). Salah satu aspek penting dalam pengembangan aplikasi web menggunakan React adalah pengambilan data atau data fetching. Ini adalah proses mengambil data dari sumber eksternal, seperti API, database, atau file, untuk digunakan dalam komponen React.
Dalam aplikasi modern, kebanyakan data disimpan di server, dan UI hanya bertindak sebagai antarmuka yang menampilkan data tersebut kepada pengguna. Data fetching memungkinkan komponen React untuk mengambil data ini secara dinamis dan menampilkannya. Tanpa data fetching, aplikasi hanya akan menampilkan data statis, yang tentunya kurang menarik dan tidak interaktif.
fetch adalah API bawaan di JavaScript yang digunakan untuk mengambil sumber daya dari server. Berikut adalah contoh sederhana menggunakan fetch di React:
1import React, { useEffect, useState } from 'react';
2
3 function DataFetchingComponent() {
4 const [data, setData] = useState([]);
5 const [loading, setLoading] = useState(true);
6
7 useEffect(() => {
8 fetch('https://api.example.com/data')
9 .then(response => response.json())
10 .then(data => {
11 setData(data);
12 setLoading(false);
13 })
14 .catch(error => {
15 console.error('Error fetching data:', error);
16 setLoading(false);
17 });
18 }, []);
19
20 if (loading) {
21 return <p>Loading...</p>;
22 }
23
24 return (
25 <div>
26 <h1>Data</h1>
27 <ul>
28 {data.map(item => (
29 <li key={item.id}>{item.name}</li>
30 ))}
31 </ul>
32 </div>
33 );
34 }
35
36 export default DataFetchingComponent;
Dalam contoh di atas, kita menggunakan useEffect untuk menjalankan operasi fetch ketika komponen dipasang (mounted). useState digunakan untuk menyimpan data yang diambil dan status loading.
axios adalah library pihak ketiga yang mempermudah proses HTTP request, terutama untuk kasus yang lebih kompleks seperti penanganan interceptors atau request cancellation. Berikut contoh implementasinya:
1import React, { useEffect, useState } from 'react';
2 import axios from 'axios';
3
4 function DataFetchingComponent() {
5 const [data, setData] = useState([]);
6 const [loading, setLoading] = useState(true);
7
8 useEffect(() => {
9 axios.get('https://api.example.com/data')
10 .then(response => {
11 setData(response.data);
12 setLoading(false);
13 })
14 .catch(error => {
15 console.error('Error fetching data:', error);
16 setLoading(false);
17 });
18 }, []);
19
20 if (loading) {
21 return <p>Loading...</p>;
22 }
23
24 return (
25 <div>
26 <h1>Data</h1>
27 <ul>
28 {data.map(item => (
29 <li key={item.id}>{item.name}</li>
30 ))}
31 </ul>
32 </div>
33 );
34 }
35
36 export default DataFetchingComponent;
axios memberikan API yang lebih bersih dan beberapa fitur tambahan dibandingkan dengan fetch.
Untuk manajemen data fetching yang lebih kompleks, seperti caching dan synchronisasi data, React Query adalah solusi yang sangat populer. Dengan React Query, pengelolaan data fetching bisa dilakukan dengan lebih efisien dan lebih sedikit kode.
1import React from 'react';
2 import { useQuery } from 'react-query';
3 import axios from 'axios';
4
5 function DataFetchingComponent() {
6 const { data, error, isLoading } = useQuery('fetchData', () =>
7 axios.get('https://api.example.com/data').then(res => res.data)
8 );
9
10 if (isLoading) return <p>Loading...</p>;
11 if (error) return <p>Error fetching data</p>;
12
13 return (
14 <div>
15 <h1>Data</h1>
16 <ul>
17 {data.map(item => (
18 <li key={item.id}>{item.name}</li>
19 ))}
20 </ul>
21 </div>
22 );
23 }
24
25 export default DataFetchingComponent;
26
Dengan React Query, kita tidak perlu khawatir tentang manajemen loading state, error handling, atau caching, karena semua itu ditangani secara otomatis.
Data fetching adalah komponen penting dalam pengembangan aplikasi React.js. Dengan menggunakan metode seperti fetch, axios, atau React Query, pengembang dapat mengambil dan menampilkan data dari server secara efisien dan efektif. Memahami berbagai teknik dan alat untuk data fetching akan membantu dalam membangun aplikasi yang lebih dinamis dan responsif.