>  기사  >  웹 프론트엔드  >  React Render 함수에서 Async/Await를 올바르게 사용하는 방법은 무엇입니까?

React Render 함수에서 Async/Await를 올바르게 사용하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-18 15:28:29500검색

How to Use Async/Await Correctly in React Render Functions?

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 }) =&gt; {
  const [addresses, setAddresses] = useState([]);

  useEffect(() =&gt; {
    Promise.all(locations.map(async (loc) =&gt; {
      const address = await Geocode.fromLatLng(loc[0], loc[1]);
      return address.results[0].formatted_address;
    }))
    .then(results =&gt; setAddresses(results));
  }, [locations]);

  return (
    &lt;tbody&gt;
      {addresses.map((addr, idx) =&gt; (
        &lt;tr key={idx}&gt;
          &lt;td&gt;{addr}&lt;/td&gt;
          &lt;td&gt;Goa&lt;/td&gt;
          &lt;td&gt;asdsad&lt;/td&gt;
          &lt;td&gt;{_.get(loc, 'driverId.email', '')}&lt;/td&gt;
          &lt;td&gt;{_.get(loc, 'driverId.mobile', '')}&lt;/td&gt;
        &lt;/tr&gt;
      ))}
    &lt;/tbody&gt;
  );
};</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

  • Separate Data Fetching from Displaying: The recommended approach is to separate data fetching from rendering. Use a parent component to perform asynchronous operations (like geocoding) and conditionally render a child component when the data is available.
  • Use Memoization: To optimize performance, consider using memoization techniques, such as useMemo in the parent component, to avoid redundant data fetching.
  • TypeScript Support: If using TypeScript, consider defining types for the geocoding results to improve type safety and avoid potential errors.

위 내용은 React Render 함수에서 Async/Await를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.