Kesalingoperasian JavaScript Menjanjikan untuk Merangkai Cekap Fungsi Async jQuery
Apabila merantai fungsi jQuery tak segerak, selalunya wajar untuk mengelakkan jQuery terbina Menjanjikan fungsi dan sebaliknya menggunakan Janji ES6 asli. Saling kendali ini membolehkan penyepaduan lancar antara tindakan jQuery dan pelaksanaan Promise yang anda inginkan.
Merangkai Dua Panggilan getJSON dengan Janji Asli
Untuk merantai dua panggilan $.getJSON tanpa menggunakan jQuery's kemudian () atau .when(), ikut langkah berikut:
Selesaikan janji jQuery pertama:
Promise.resolve($.getJSON(url1, params1));
Rantai panggilan kedua dalam panggilan asli kemudian panggil balik:
.then((data1) => { return $.getJSON(url2, params2); })
Kaedah ini memastikan bahawa panggilan kedua hanya dilaksanakan selepas panggilan pertama berjaya diselesaikan, tanpa bergantung pada seni bina Janji jQuery.
Mengantaramuka dengan Kaedah Bukan Standard
Walaupun janji JavaScript boleh dioperasikan, menggunakan kaedah atau ciri bukan standard memerlukan penghantaran yang jelas. Sebagai contoh, untuk mengakses kaedah khusus jQuery dalam rantai Promise asli, gunakan Promise.resolve() untuk menghantar Janji jQuery ke dalam kaedah asli sebelum menggunakan kaedah:
Promise.resolve($.ajax(…)) .then((data) => { // Use jQuery-specific method data.foo(); })
Pendekatan ini memastikan bahawa kaedah foo() digunakan dalam konteks rantai Promise asli.
Ringkasnya, dengan memahami kebolehoperasian janji JavaScript, anda boleh menggabungkan keupayaan tak segerak jQuery dengan lancar dengan pelaksanaan Promise yang diingini untuk rantaian operasi asinkron yang cekap .
Atas ialah kandungan terperinci Bagaimanakah saya boleh memanfaatkan Janji ES6 asli untuk merantai fungsi jQuery tak segerak dengan cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!