ホームページ >ウェブフロントエンド >htmlチュートリアル >$http と ajax 間の同期リクエスト (コード例)

$http と ajax 間の同期リクエスト (コード例)

云罗郡主
云罗郡主転載
2018-10-17 14:11:454222ブラウズ

この記事は $http と ajax の同期リクエスト (コード例) に関するもので、必要な方は参考にしていただければ幸いです。

Web フロントエンド開発では、通常、ほとんどの機能要件を解決するために非同期ネットワーク リクエストが使用されますが、特定のニーズの場合には、依然として同期ネットワーク リクエストを使用して特殊な問題を解決する必要があります。そこでこの記事では、AngularJS の $http と jQuery の ajax を使用して同期ネットワーク リクエストを実装する方法を紹介します。

(1) $http 同期ネットワーク リクエスト

実際、この実装は非常に単純です。重要なのは 2 つの点です。1 つ目は直接返すことです。成功したコールバック メソッドの結果 2 番目の点は、$http 自体が実行後に直接 Promise オブジェクトを返すことです。これら 2 つの要件を満たすことで、$http の同期を実現できます。

最終的なネットワーク要求によって取得された結果セットは、返された Promise オブジェクトに含まれます。

テンプレートコード実装:

 let requestConfig = {
            url:"...",
            method:"post"
        };
        let promise = $http(requestConfig).then(function (response) {
            return response;
        });
        console.log("结果在promise对象中",promise);

(2) Ajax 同期ネットワークリクエスト

ajax のネットワーク同期実行を実現するには、次の 2 点も重要です。 1 番目のポイントは、リクエスト パラメーターで async の値を false に設定することです。2 番目のポイントは、ajax の成功または失敗のコールバック メソッドを記述せず、ajax の実行後に取得された結果セットを直接返すことです。これら 2 つの要件を満たすことで、ajax の同期実装を実現できます。

テンプレート コードの実装:

 let result = $.ajax({
            url:"...",
            type:"get",
            async:false
        });
        console.log("返回结果直接是result",result);

上記は、$http と ajax の同期リクエスト (コード例) の完全な紹介です。 について詳しく知りたい場合は、 HTML ビデオ チュートリアル 、PHP 中国語 Web サイトに注意してください。

以上が$http と ajax 間の同期リクエスト (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcsdn.netで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。