Understanding Async/Await in React Render Functions
Asynchronous programming, enabled by async/await syntax, is common in back-end development, such as Node.js, but can also be applied in front-end scenarios within React render functions.
Use Case: Geocoding with react-geocode
Consider a scenario where you need to obtain the place name for multiple locations using the react-geocode library and display them in a React table:
<code class="js">import React, { useEffect, useState } from 'react'; import Geocode from 'react-geocode'; import _ from 'lodash'; const GeocodeTable = ({ locations }) => { const [addresses, setAddresses] = useState([]); useEffect(() => { Promise.all(locations.map(async (loc) => { const address = await Geocode.fromLatLng(loc[0], loc[1]); return address.results[0].formatted_address; })) .then(results => setAddresses(results)); }, [locations]); return ( <tbody> {addresses.map((addr, idx) => ( <tr key={idx}> <td>{addr}</td> <td>Goa</td> <td>asdsad</td> <td>{_.get(loc, 'driverId.email', '')}</td> <td>{_.get(loc, 'driverId.mobile', '')}</td> </tr> ))} </tbody> ); };</code>
Mistakes to Avoid
In your original code, you attempted to use async/await directly within the map function of the render function. This is not supported and will result in an empty return.
Best Practices
以上がReact レンダー関数で Async/Await を正しく使用する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。