vuejsでajaxを使用する方法

青灯夜游
リリース: 2023-01-11 09:21:48
オリジナル
3468 人が閲覧しました

方法: 1. axios をインストールして導入し、「axios([option])」や「axios.get(url[,...])」などのメソッドを使用してリクエストを送信します。 2. vue-resourceをインストールして導入し、「this.$http.jsonp(url,[...])」を使用してリクエストを送信します。

vuejsでajaxを使用する方法

このチュートリアルの動作環境: Windows7 システム、vue2.9.6 バージョン、DELL G3 コンピューター。

Vue 自体は AJAX リクエストの送信をサポートしていないため、vue-resource や axios などのプラグインを使用して実装する必要があります。

axios は、リクエストの送信に使用される Promise ベースの HTTP リクエスト クライアントです。vue2.0 でも公式に推奨されています。同時に、vue-resource は更新および保守されなくなります。

vuejs が ajax を使用する方法

1. axios をインストールし、

1) npm を導入します。方法: npm install axios -S

2) bower の方法: bower install axios

3) cdn の方法: <script src="https://unpkg.com%20/axios/dist/axios.min.js"></script>

2. 基本的な使用法

1) axios([options ] )

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>axios发送ajax请求基本用法</title>
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
</head>
<body>
    <div id="app">
        <button @click="send">发送ajax请求</button>
    </div>
    <script>
        new Vue({
            el:"#app",
            methods:{
                send(){
                    axios({
                       method:&#39;get&#39;,
                        url:&#39;user.json&#39;
                    }).then(function(res){
                        console.log(res.data.name);
                    });
                }
            }
        });
    </script>
</body>
</html>
ログイン後にコピー

vuejsでajaxを使用する方法
2) axios.get(url[,options]);

パラメータの受け渡し方法:
(1) URLパラメータの受け渡しaxios('url?key=value&key1=val2').then();
(2) params オプションを介してパラメータ axios('url',{params:{key:value}}).then(); を渡します

3) axios.post(url,data,[options]);

axios がデフォルトでデータを送信する場合、データ形式は一般的に使用されるリクエスト ペイロードではありません。フォーム データ形式、
したがって、パラメーターは、json 形式ではなく、キーと値のペアの形式で渡す必要があります。

パラメータの受け渡し方法:

(1) 自分でキーと値のペアに結合します

axios.post(‘url’,’key=value&key1=value1’).then();
ログイン後にコピー

(2) 前に、transformRequest を使用してリクエストを変換しますデータ変換の送信

axios.post(&#39;url&#39;,data,{
                        transformRequest:[
                                function(data){
                                    let params = &#39;&#39;;
                                    for(let index in data){
                                        params +=index+&#39;=&#39;+data[index]+&#39;&&#39;;
                                    }
                                    return params;
                                }
                        ]
                    }).then(function(res){
                        console.log(res.data)
                    });
ログイン後にコピー

(3) モジュラー開発を使用する場合は、変換に qs モジュールを使用できます

axios 自体はクロスドメイン リクエストの送信をサポートしていません対応する API については、作者は axios でクロスドメイン リクエストを送信するためのサポートを追加する予定はありません。
したがって、サードパーティ ライブラリのみを使用できます

クロスドメインリクエスト (vue-resource を使用してクロスドメインリクエストを送信)

1. vue-resource を使用してクロスドメインリクエストを送信する手順

  • vue-resource をインストールしてインポートします :npm install vue-resource -S
  • 基本的な使用法:

これを使用します。 http.jsonp(url,[ops]) でリクエストを送信します

2. 基本的な使用方法のデモ (360 検索)

1) 360 検索を開きます。次に、文字「a」を入力すると、図
vuejsでajaxを使用する方法
に示すように、いくつかの検索オプションが自動的に表示されます。


2) リンクをコピー

https://sug.so.360.cn/ recommend?callback=suggest_so&encodein=utf-8&encodeout=utf-8&format=json&fields=word&word=a

3) コードのデモ

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>使用vue-resource发送跨域请求</title>
    <!--引入vue、vue-resource文件-->
    <script src="vue.min.js"></script>
    <script src="vue-resource.min.js"></script>
</head>
<body>
    <div id="app">
        <button @click="sendJsonp">send</button>
    </div>
    <script>
            var vm = new Vue({
                el:"#app",
                methods:{
                    sendJsonp:function(){
                        this.$http.jsonp(&#39;https://sug.so.360.cn/suggest&#39;,{
                            params:{
                                word:&#39;a&#39;
                            }
                        }).then(function(res){
                            console.log(res.data);
                        });
                    }
                }
            });
    </script>
</body>
</html>
ログイン後にコピー
vuejsでajaxを使用する方法vuejsでajaxを使用する方法4) 結果

3. 基本的なデモ例 (Baidu 検索)

vuejsでajaxを使用する方法 1) 要件は 360 検索と同じです



2 ) リンクをコピー

=1526436420943">https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=a&json= 1&p=3&sid=1467_21117_20927&req=2&csor=1&cb=jQuery110206030510278 4707_1526436420940&=1526436420943

3) コードのデモ (注) – 最初の試行

上記のコードに従って書くと結果はエラーになります

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>使用vue-resource发送跨域请求</title>
    <!--引入vue、vue-resource文件-->
    <script src="vue.min.js"></script>
    <script src="vue-resource.min.js"></script>
</head>
<body>
    <div id="app">
        <button @click="sendJsonp">send</button>
    </div>
    <script>
            var vm = new Vue({
                el:"#app",
                methods:{
                    sendJsonp:function(){  
               this.$http.jsonp(&#39;https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su&#39;,{
                            params:{
                                wd:&#39;a&#39;
                            }
                        }).then(function(res){
                            console.log(res.data);
                        });
                    }
                }
            });
    </script>
</body>
</html>
ログイン後にコピー
百度搜过vuejsでajaxを使用する方法报错結果はエラーになります

ではなぜですか

以前の 360 search jsonp コールバックのパラメータ名は callback でしたが、Baidu で使用されていたパラメータ名は cb だったので、エラーが報告されます

修正したコードは以下の通りです

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>使用vue-resource发送跨域请求</title>
    <!--引入vue、vue-resource文件-->
    <script src="vue.min.js"></script>
    <script src="vue-resource.min.js"></script>
</head>
<body>
    <div id="app">
        <button @click="sendJsonp">send</button>
    </div>
    <script>
            var vm = new Vue({
                el:"#app",
                methods:{
                    sendJsonp:function(){
         this.$http.jsonp(&#39;https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su&#39;,{
                            params:{
                                wd:&#39;a&#39;
                            },
                            jsonp:&#39;cb&#39;
                        }).then(function(res){
                            console.log(res.data);
                        });
                    }
                }
            });
    </script>
</body>
</html>
ログイン後にコピー
vuejsでajaxを使用する方法vuejsでajaxを使用する方法4)結果

##4、Baidu検索事例デモ

関連する推奨事項: 「vue.js チュートリアル ###」###

以上がvuejsでajaxを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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