Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimanakah Async/Await boleh digunakan untuk menukar fungsi pemuatan imej berasaskan panggilan balik kepada pendekatan berasaskan janji untuk akses data imej segerak?

Bagaimanakah Async/Await boleh digunakan untuk menukar fungsi pemuatan imej berasaskan panggilan balik kepada pendekatan berasaskan janji untuk akses data imej segerak?

Patricia Arquette
Patricia Arquetteasal
2024-11-02 13:09:03552semak imbas

How can Async/Await be used to convert a callback-based image loading function into a promise-based approach for synchronous image data access?

Menggunakan Async/Await untuk Menukar Panggilan Balik kepada Janji

Dalam JavaScript, fungsi berikut mendapatkan semula data imej daripada URL:

<code class="javascript">function getImageData(url) {
  const img = new Image();
  img.addEventListener('load', function() {
    return { width: this.naturalWidth, height: this.naturalHeight };
  });
  img.src = url;
}</code>

Fungsi ini menggunakan pendekatan panggil balik, tetapi ia memberikan had apabila cuba mengakses data imej secara serentak. Jika anda menggunakan getImageData dalam kaedah sedia seperti berikut:

<code class="javascript">ready() {
  console.log(getImageData(this.url));
}</code>

anda akan memperoleh undefined kerana imej itu belum dimuatkan lagi. Oleh itu, adalah perlu untuk menggunakan teknik tak segerak untuk mengendalikan operasi pemuatan imej sebelum mengakses data imej.

Untuk mencapai matlamat ini, anda boleh memanfaatkan pembina Promise seperti berikut:

<code class="javascript">function loadImage(url) {
  return new Promise((resolve, reject) => {
    const img = new Image();
    img.addEventListener('load', () => resolve(img));
    img.addEventListener('error', reject); // Handle error cases as well
    img.src = url;
  });
}</code>

Sekarang , anda boleh menggunakan async/await untuk menunggu janji loadImage dan seterusnya mendapatkan semula data imej:

<code class="javascript">async function getImageData(url) {
  const img = await loadImage(url);
  return { width: img.naturalWidth, height: img.naturalHeight };
}

async function ready() {
  console.log(await getImageData(this.url));
}</code>

Dalam pelaksanaan yang diubah suai ini, async/waiit memastikan bahawa kod dijeda sehingga janji loadImage diselesaikan, justeru menjamin bahawa data imej tersedia pada masa pengelogan.

Atas ialah kandungan terperinci Bagaimanakah Async/Await boleh digunakan untuk menukar fungsi pemuatan imej berasaskan panggilan balik kepada pendekatan berasaskan janji untuk akses data imej segerak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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