Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Menyusun dan Berkongsi Data dengan Cekap Antara Janji dalam JavaScript?

Bagaimana untuk Menyusun dan Berkongsi Data dengan Cekap Antara Janji dalam JavaScript?

DDD
DDDasal
2024-12-01 02:52:11688semak imbas

How to Efficiently Sequence and Share Data Between Promises in JavaScript?

Cara Menjujukan dan Berkongsi Data dalam Rantai Janji

Promise menawarkan alat yang berkuasa untuk mengurus operasi tak segerak dalam JavaScript. Sebagai sebahagian daripada ini, ia menjadi perlu untuk menyusun operasi dan berkongsi data antara mereka. Mari kita atasi isu khusus:

Merangkai Permintaan HTTP dan Perkongsian Data dengan Janji

Dalam senario ini, anda menggunakan Promises untuk melaksanakan satu siri permintaan HTTP, di mana respons daripada satu permintaan hendaklah digunakan sebagai input untuk permintaan seterusnya. Fungsi callhttp mengendalikan permintaan ini tetapi perlu mengakses data daripada permintaan sebelumnya untuk membina permintaan seterusnya. Secara khususnya, anda ingin menghantar kunci API yang diperoleh daripada permintaan pertama kepada permintaan seterusnya.

Pendekatan untuk Perkongsian dan Penjujukan Data

Terdapat beberapa pendekatan untuk mencapai perkara ini:

1. Janji Berantai:

Rantai janji menggunakan kemudian, menghantar data perantaraan sebagai hujah:

callhttp(url1, payload)
    .then(firstResponse => {
        // Use the data from firstResponse in the next request
        return callhttp(url2, payload, firstResponse.apiKey);
    })
    .then(secondResponse => {
        // Use the combined data from firstResponse and secondResponse in the next request
        return callhttp(url3, payload, firstResponse.apiKey, secondResponse.userId);
    });

2. Tugasan Skop Lebih Tinggi:

Tugaskan hasil perantaraan kepada pembolehubah dalam skop yang lebih tinggi:

var firstResponse;
callhttp(url1, payload)
    .then(result => {
        firstResponse = result;
        return callhttp(url2, payload);
    })
    .then(secondResponse => {
        // Use both firstResponse and secondResponse here
    });

3. Hasil Terkumpul:

Simpan hasil dalam objek terkumpul:

var results = {};
callhttp(url1, payload)
    .then(result => {
        results.first = result;
        return callhttp(url2, payload);
    })
    .then(result => {
        results.second = result;
        return callhttp(url3, payload);
    })
    .then(() => {
        // Use the accumulated results in results object
    });

4. Janji Bersarang:

Nest berjanji untuk mengekalkan akses kepada semua hasil carian sebelumnya:

callhttp(url1, payload)
    .then(firstResponse => {
        // Use firstResponse here
        return callhttp(url2, payload)
            .then(secondResponse => {
                // Use both firstResponse and secondResponse here
                return callhttp(url3, payload);
                    .then(thirdResponse => {
                        // Use all three responses here
                    });
            });
    });

5. Berpisah dengan Promise.all():

Jika sesetengah permintaan boleh dibuat secara berasingan, pecahkan rantai itu kepada bahagian yang berasingan dan gunakan Promise.all() untuk mengumpul keputusan:

const first = callhttp(url1, payload);
const second = callhttp(url2, payload);
const third = callhttp(url3, payload);

Promise.all([first, second, third])
    .then(results => {
        // Use all three results here
    });

ES7 Async/Await:

Dalam ES7, async/menunggu sintaks memperkemas proses penjujukan dan pengendalian hasil janji, menyediakan kod yang lebih mudah dan boleh dibaca:

async function httpRequests() {
    const firstResponse = await callhttp(url1, payload);
    const secondResponse = await callhttp(url2, payload, firstResponse.apiKey);
    const thirdResponse = await callhttp(url3, payload, firstResponse.apiKey, secondResponse.userId);

    // Use all three responses here
}

httpRequests();

Atas ialah kandungan terperinci Bagaimana untuk Menyusun dan Berkongsi Data dengan Cekap Antara Janji dalam JavaScript?. 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