ホームページ > ウェブフロントエンド > jsチュートリアル > React レンダー関数で Async/Await を正しく使用する方法は?

React レンダー関数で Async/Await を正しく使用する方法は?

DDD
リリース: 2024-10-18 15:28:29
オリジナル
570 人が閲覧しました

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 レンダー関数で Async/Await を正しく使用する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート