ホームページ > ウェブフロントエンド > フロントエンドQ&A > ではes6ではどのように書くのでしょうか?

ではes6ではどのように書くのでしょうか?

WBOY
リリース: 2022-05-06 16:40:28
オリジナル
3528 人が閲覧しました

es6 では、then の記述方法は「then (Promise インスタンスに状態変化成功時のコールバック関数、失敗時のコールバック関数を追加)」となっており、このメソッドは、Promise インスタンスに対するコールバック関数を追加するために使用されます。状態が変化したときの Promise インスタンス。返される結果は新しい Promise インスタンスであり、メソッドは連鎖操作を使用できます。

ではes6ではどのように書くのでしょうか?

このチュートリアルの動作環境: Windows 10 システム、ECMAScript バージョン 6.0、Dell G3 コンピューター。

es6のthenの書き方とは

書き方:

then(参数1,参数2)
ログイン後にコピー

機能:状態変化時のコールバック関数を追加するPromise インスタンスへ

##パラメータ 1 は成功時のコールバック関数、

パラメータ 2 は失敗時のコールバック関数

戻り値: then() メソッド新しい Promise インスタンスを返すと、 then() メソッドはチェーン操作を使用できます。

知識を増やす:

Promise

1. 概念: Promise は解決策.

2. 非同期: これまでの非同期操作の実装方法: ①コールバック関数 ②イベントトリガー

3. 機能: 非同期操作とは異なる問題を解決します。

4. 特徴: ①: オブジェクトの状態は外界の影響を受けない Promise オブジェクトは非同期操作を表し、次の 3 つの状態があります: Pending (進行中).fulfilled ( success).rejected (failed). 非同期操作の結果のみが現在の状態を決定でき、他の操作ではこの状態を変更できません。

②: オブジェクトの状態は一度変更されると変更されません。この結果はいつでも再度取得できます (Promise オブジェクトの状態が変化する可能性は 2 つだけです: 保留から履行へ、および保留から拒否へ)。

5: 基本的な使用法

(1) 新しいPromiseオブジェクトを通じてPromiseインスタンスを作成できます

const promise=new Promise(function(resolve,reject){})
ログイン後にコピー

(2) パラメータの説明: Promiseオブジェクトはパラメータとして関数を受け取ります。この関数のパラメータはresolveとrejectです。 Javascriptエンジンが提供する2つの関数です

(3)resolve関数の役割:非同期操作が成功したときに呼び出され、非同期操作の結果がパラメータとして渡されます。

(4) リジェクト関数の役割: 非同期操作が失敗したときに呼び出され、非同期操作の結果がパラメータとして渡されます。非同期操作によって報告されたエラーはパラメータとして渡されます。

注意: Promise インスタンスが生成された後、then メソッドを使用して成功コールバック関数と失敗コールバック関数をそれぞれ指定できます。

.then() は、Promise インスタンスであり、実行される次の操作を示すメソッドです。

例:

function ajax(){
            console.log("hello");
            return new Promise(function(resolve,reject){
                    setTimeout(function(){
                        resolve();
                    },1000)
                })
                ajax.then(function(){
                    console.log("world");
                })
            }
ログイン後にコピー

6. Promise インスタンスのメソッド

(1)then(パラメータ 1, パラメータ 2)

関数: コールバックの追加状態が Promise インスタンスに変化するときの関数

パラメーター 1 は成功したコールバック関数、パラメーター 2 は失敗したコールバック関数です

戻り値: then() このメソッドは新しい Promise インスタンスを返します。

(2)catch()

関数:エラー発生時のコールバック関数を指定します、関数は同じです。 then メソッド

例:

let ajax=function(num){
                return new Promise((resolve,reject){
                    if(num>5){
                        resolve(num);
                    }else{
                           throw new Error("出错了");
                        }
                })
            }
               ajax(2).then(function(num){
                console.log(num);
            }).catch(function(error){
                console.log(error);
            })
ログイン後にコピー

7. Promise の高度なメソッド

(1)promise.all()

機能 : 複数の Promise をパックするインスタンスを新しい Promise インスタンスに追加します。簡単に言うと、成功したコールバックは複数の非同期操作が成功した場合にのみ実行され、それ以外の場合は失敗したコールバックが実行されます。

パラメータの説明: 配列をパラメータとして受け取り、各項目は配列は Promise インスタンスです。

(2)promise.race()

関数: 最初に状態を変更するインスタンスが存在する限り、複数の Promise インスタンスを新しい Promise インスタンスにパックします。

パラメータの説明: 配列をパラメータとして受け取り、配列の各項目は Promise インスタンスです

8. Promise スタイル AjAx

                function promiseAjax(json){
                    let url=json.url;
                    let type=json.type||"get";
                    let data=json.data||{};
                    let str="";
                    for(let k in data){
                        str+=k+"="+data[k]+"&";
                    }
                    return new Promise((resolve,reject)=>{
                    let ajax=new XMLHttpRequest();
                    if(type.toLowerCase()==="get"){
                        ajax.open("get",`${url}?${str}time=${Date.now()}`,true);
                        ajax.send();
                    }else if(type.toLowerCase()==="post"){
                        ajax.open("post",url,true);
                        ajax.setRequestHeader("content-type","application/x-www-form-urlencoded");
                        ajax.send(str.substring(0,str.laseIndexOf("&")));
                    }
                        ajax.onreadystatechange=function(){
                            if(ajax.readyState===4){
                                if(ajax.status>=200&&ajax.status<300){
                                    resolve(JSON.parse(ajax.responseText));
                                }else{
                                    let error=new Error();
                                    error.status=ajax.status;
                                    reject(error);
                                }
                            }
                        }
                    })
            }
ログイン後にコピー

[関連する推奨事項:

JavaScript ビデオ チュートリアル

Web フロントエンド ]

以上がではes6ではどのように書くのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
es6
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート