React Data Cache Guide : Comment optimiser l'efficacité de l'acquisition et de la mise à jour des données frontales
Introduction :
Lors du développement d'applications Web, nous avons souvent besoin d'obtenir des données du backend et de les afficher sur le frontend. Cependant, chaque fois que vous obtenez des données, vous devez envoyer une requête au serveur, ce qui entraînera un certain retard et affectera l'expérience utilisateur. Afin d'améliorer l'efficacité de l'obtention et de la mise à jour des données frontales, nous pouvons utiliser la technologie de mise en cache des données. Cet article expliquera comment utiliser la mise en cache des données dans les applications React pour optimiser l'acquisition de données et l'efficacité de la mise à jour, et fournira des exemples de code spécifiques.
Ce qui suit est un exemple de code utilisant la bibliothèque Cache
: Cache
库的示例代码:
import Cache from 'cache'; const dataCache = new Cache(); function fetchData(url) { if (dataCache.has(url)) { return Promise.resolve(dataCache.get(url)); } return fetch(url) .then(response => response.json()) .then(data => { dataCache.set(url, data); return data; }); } fetchData('/api/data1') .then(data => console.log(data));
在上述示例中,dataCache
是一个缓存实例,我们使用has
方法检查缓存是否存在相应的数据,如果存在则直接返回,否则通过fetch
方法从API获取数据,并存入缓存,然后返回数据。
以下是一个使用React Context的示例代码:
// 创建一个Context const DataContext = React.createContext(); // 提供数据的组件 function DataProvider({ children }) { const [data, setData] = useState(null); useEffect(() => { fetch('/api/data') .then(response => response.json()) .then(data => setData(data)); }, []); return ( <DataContext.Provider value={data}> {children} </DataContext.Provider> ); } // 使用数据的组件 function DataConsumer() { const data = useContext(DataContext); if (data === null) { return <div>Loading...</div>; } return ( <div>{data}</div> ); } // 在应用程序中使用数据 function App() { return ( <DataProvider> <DataConsumer /> </DataProvider> ); } ReactDOM.render(<App />, document.getElementById('root'));
在上述示例中,我们创建了一个DataContext
通过createContext
方法,并在DataProvider
组件中获取数据并传递给DataContext.Provider
。然后,在DataConsumer
组件中使用useContext
方法获取数据,如果数据为空则显示"Loading...",否则展示数据。
以下是一个使用Redux的示例代码:
import { createStore } from 'redux'; // 定义数据状态的reducers function dataReducer(state = null, action) { switch (action.type) { case 'SET_DATA': return action.payload; default: return state; } } // 创建store const store = createStore(dataReducer); // 获取数据的动作 function fetchData() { return dispatch => { if (store.getState() !== null) { return; } fetch('/api/data') .then(response => response.json()) .then(data => { dispatch({ type: 'SET_DATA', payload: data }); }); }; } // 在应用程序中使用数据 store.dispatch(fetchData()); function App() { const data = store.getState(); if (data === null) { return <div>Loading...</div>; } return ( <div>{data}</div> ); } ReactDOM.render(<App />, document.getElementById('root'));
在上述示例中,我们先定义一个数据状态的reducer,在fetchData
动作中获取数据并通过dispatch
方法将数据存入store。然后,在App
组件中使用store.getState
rrreee
dataCache
est une instance de cache et nous utilisons has code >La méthode vérifie si les données correspondantes existent dans le cache, et renvoie directement si elles existent. Sinon, elle obtient les données de l'API via la méthode <code>fetch
, les stocke dans le cache, puis. renvoie les données.
DataContext
via la méthode createContext
et l'avons utilisé dans le DataProvider DataContext.Provider
. Ensuite, utilisez la méthode useContext
dans le composant DataConsumer
pour obtenir les données. Si les données sont vides, "Loading..." sera affiché, sinon les données seront affichées. affiché. 🎜fetchData
et les transmettons via La méthode dispatch code> stocke les données dans le magasin. Ensuite, utilisez la méthode <code>store.getState
dans le composant App
pour obtenir les données. Si les données sont vides, "Loading..." sera affiché, sinon les données. sera affiché. 🎜🎜Conclusion : 🎜En utilisant la technologie de mise en cache des données, nous pouvons considérablement améliorer l'efficacité de l'obtention et de la mise à jour des données frontales, réduire les requêtes réseau inutiles et améliorer l'expérience utilisateur. Cet article présente trois technologies courantes de mise en cache de données utilisant des bibliothèques de mise en cache, React Context et Redux, et fournit des exemples de code spécifiques. J'espère que cet article vous aidera à comprendre et à appliquer la mise en cache des données. 🎜
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!