Bagaimana untuk Menggunakan Async/Menunggu dengan betul dalam Fungsi Render React?

DDD
Lepaskan: 2024-10-18 15:28:29
asal
430 orang telah melayarinya

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>
Salin selepas log masuk

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.

Atas ialah kandungan terperinci Bagaimana untuk Menggunakan Async/Menunggu dengan betul dalam Fungsi Render React?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!