AngularJS_AngularJS で複数の Promise を処理する方法
AngularJS を使用して Promise を処理する場合、複数の Promise を処理する必要がある状況に遭遇することがあります。
最も簡単な解決策は、Promise ごとに then を設定することです。以下のように:
var app = angular.module("app",[]); app.controller("AppCtrl", function($q. $timeout){ var one = $q.defer(); var two = $q.defer(); var three = $q.defer(); $timeout(function(){ one.resolve("one done"); }, Math.random() * 1000) $timeout(function(){ two.resolve("two done"); }, Math.random() * 1000) $timeout(function(){ three.resolve("three done"); }, Math.random() * 1000) functioin success(data){ console.log(data); } one.promise.then(success); two.promise.then(success); three.promise.then(success); })
もっと良い方法はありますか?
$q.all メソッドは Promise の配列を受け入れることができ、次のように呼び出されます:
var all = $q.all([one.promise, two.promise, three.promise]); all.then(success);
約束とは何ですか?
Promise は、値を非同期に処理するメソッドであり、リモート オブジェクトを扱う場合、関数によってスローされる最終的な戻り値または例外を表します。 。 Promiseも非同期処理メソッドの一種だとすると、XHRや$.ajaxとの違いを考えてみますか?
JS ではクロージャまたはコールバックを使用して、ページが読み込まれた後の XHR リクエストなどの非同期に返されたデータに応答するのが一般的です。コールバック関数のトリガーに依存せずに、データが返されたかのように通常どおりデータを操作できます。
では、ng が提案した約束は、どのような問題を解決することを目的としているのでしょうか? コールバックは長い間使用されてきましたが、他のコールバックに依存するコールバックがあり、呼び出しのたびにエラーを表示する必要がある場合、通常はデバッグが非常に困難になります。違いは、Promise が別の抽象化を提供することです。これらの関数は Promise オブジェクトを返します。
Promise を使用する理由
Promise を使用する利点の 1 つは、コールバックの固定された思考ロジックから逃れられることです。 Promise は、同期関数に基づいて、非同期処理メカニズムを同期に似せて、期待どおりに戻り値と例外値をキャプチャできます。エラーはプログラム内でいつでも捕捉でき、プログラム例外に依存する後続のコードをバイパスできます。この同期の利点について考える必要はありません。したがって、Promise を使用する目的は、コードを非同期で実行する機能を維持しながら、機能の組み合わせとエラー バブリング機能を取得することです。
Promise はファーストクラスのオブジェクトであり、いくつかの規則があります。
• 解決または拒否は 1 つだけ呼び出されます。
• Promise が実行または拒否された場合でも、Promise に依存するハンドラーは引き続き呼び出されます。
• ハンドラーは常に非同期で呼び出されます。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











JavaScript文字列置換法とFAQの詳細な説明 この記事では、javaScriptの文字列文字を置き換える2つの方法について説明します:内部JavaScriptコードとWebページの内部HTML。 JavaScriptコード内の文字列を交換します 最も直接的な方法は、置換()メソッドを使用することです。 str = str.replace( "find"、 "置換"); この方法は、最初の一致のみを置き換えます。すべての一致を置き換えるには、正規表現を使用して、グローバルフラグGを追加します。 str = str.replace(/fi

楽なWebページレイアウトのためにjQueryを活用する:8本質的なプラグイン jQueryは、Webページのレイアウトを大幅に簡素化します。 この記事では、プロセスを合理化する8つの強力なjQueryプラグイン、特に手動のウェブサイトの作成に役立ちます

それで、あなたはここで、Ajaxと呼ばれるこのことについてすべてを学ぶ準備ができています。しかし、それは正確には何ですか? Ajaxという用語は、動的でインタラクティブなWebコンテンツを作成するために使用されるテクノロジーのゆるいグループ化を指します。 Ajaxという用語は、もともとJesse Jによって造られました

10の楽しいjQueryゲームプラグインして、あなたのウェブサイトをより魅力的にし、ユーザーの粘着性を高めます! Flashは依然としてカジュアルなWebゲームを開発するのに最適なソフトウェアですが、jQueryは驚くべき効果を生み出すこともできます。また、純粋なアクションフラッシュゲームに匹敵するものではありませんが、場合によってはブラウザで予期せぬ楽しみもできます。 jquery tic toeゲーム ゲームプログラミングの「Hello World」には、JQueryバージョンがあります。 ソースコード jQueryクレイジーワードコンポジションゲーム これは空白のゲームであり、単語の文脈を知らないために奇妙な結果を生み出すことができます。 ソースコード jquery鉱山の掃引ゲーム

記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

このチュートリアルでは、Ajaxを介してロードされた動的なページボックスの作成を示しており、フルページのリロードなしでインスタントリフレッシュを可能にします。 JQueryとJavaScriptを活用します。カスタムのFacebookスタイルのコンテンツボックスローダーと考えてください。 重要な概念: ajaxとjquery

このJavaScriptライブラリは、Cookieに依存せずにセッションデータを管理するためにWindow.nameプロパティを活用します。 ブラウザ全体でセッション変数を保存および取得するための堅牢なソリューションを提供します。 ライブラリは、セッションの3つのコア方法を提供します

このチュートリアルでは、jQueryを使用して魅惑的な視差の背景効果を作成する方法を示しています。 見事な視覚的な深さを作成するレイヤー画像を備えたヘッダーバナーを構築します。 更新されたプラグインは、jQuery 1.6.4以降で動作します。 ダウンロードしてください
