コールバック関数とは何ですか?通常の関数との違いは何ですか?
コールバックと比較して、Promise はどのようにコードの可読性を向上させ、非同期操作を管理しますか?
Promise の主な状態は何ですか?また、これらの状態の間はどのように遷移しますか?
Promises を使用してエラーを処理するにはどうすればよいですか?また、コールバックによるエラー処理と比較するとどうなりますか?
Promise.all と Promise.race の違いは何ですか?それぞれをいつ使用しますか?
async/await 構文は Promise の操作をどのように簡素化しますか?また、await を使用するためのルールは何ですか?
進化する JavaScript の状況では、非同期操作を効率的に管理することが、パフォーマンスの高い Web アプリケーションを構築するための鍵となります。コールバックが元のアプローチでしたが、Promise では、非同期タスクを処理するためのより構造化された読みやすい方法が導入されました。このブログでは、Promise とコールバックの使用の複雑さを詳しく掘り下げます。ただし、これらの概念についてすでに基礎を理解していることを前提としています。
コールバックは機能しますが、多くの場合、「コールバック地獄」として知られる深く入れ子になった構造になり、コードの読み取りと保守が困難になります。
fetchData(function(response1) { fetchMoreData(response1, function(response2) { fetchEvenMoreData(response2, function(response3) { console.log(response3); }); }); });
fetchData() .then(response1 => fetchMoreData(response1)) .then(response2 => fetchEvenMoreData(response2)) .then(response3 => console.log(response3)) .catch(error => console.error(error));
コールバックを使用すると、エラー オブジェクトを渡して各レベルで処理する必要があるため、エラー処理が煩雑になる可能性があります。
function fetchData(callback) { setTimeout(() => { if (/* error condition */) { callback(new Error('An error occurred'), null); } else { callback(null, 'data'); } }, 1000); } fetchData((error, data) => { if (error) { console.error(error); } else { console.log(data); } });
function fetchData() { return new Promise((resolve, reject) => { setTimeout(() => { if (/* error condition */) { reject(new Error('An error occurred')); } else { resolve('data'); } }, 1000); }); } fetchData() .then(data => console.log(data)) .catch(error => console.error(error));
Promise.all は、続行する前に複数の非同期操作が完了するまで待つ必要がある場合に便利です。
const promise1 = Promise.resolve(3); const promise2 = 42; const promise3 = new Promise((resolve, reject) => { setTimeout(resolve, 100, 'foo'); }); Promise.all([promise1, promise2, promise3]).then(values => { console.log(values); // [3, 42, "foo"] });
Promise.race は、最速の操作の結果が必要な場合に役立ちます。
const promise1 = new Promise((resolve, reject) => { setTimeout(resolve, 500, 'one'); }); const promise2 = new Promise((resolve, reject) => { setTimeout(resolve, 100, 'two'); }); Promise.race([promise1, promise2]).then(value => { console.log(value); // "two" });
async/await 構文を使用すると、同期しているように見える非同期コードを作成できるため、可読性が向上し、Promise の連鎖の複雑さが軽減されます。
async function fetchData() { return 'data'; } async function processData() { try { const data = await fetchData(); console.log(data); } catch (error) { console.error(error); } } processData();
コールバックは JavaScript で非同期操作を処理するための基礎を築きましたが、Promise は非同期コードの可読性、保守性、およびエラー処理機能を大幅に向上させました。これらのツールをいつ、どのように効果的に使用するかを理解することは、最新の JavaScript 開発にとって重要です。 Promises と async/await 構文を使用すると、開発者はよりクリーンで管理しやすいコードを作成でき、より堅牢なアプリケーションへの道が開かれます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3