ホームページ > ウェブフロントエンド > jsチュートリアル > VueJsを使用したAxiosインターフェースリクエストツールの構築に関する分析

VueJsを使用したAxiosインターフェースリクエストツールの構築に関する分析

小云云
リリース: 2017-12-18 14:51:03
オリジナル
2113 人が閲覧しました

この記事では、主に VueJs で構築された Axios インターフェイス リクエスト ツールの分析について説明します。今日は、Axios インターフェイス リクエスト ツールを構築するための VueJ を紹介します。必要な方はこの記事を参考にしていただければ幸いです。 axiosは、ブラウザとNodejsの約束ベースのHTTPクライアントです

Promise APIのサポート

    リクエストとレスポンスのインターセプト

  1. リクエストとレスポンスのデータを変換

  2. リクエストを自動的にキャンセル

  3. JSON データを変換します

  4. クライアントは CSRF/XSRF の防止をサポートします

  5. 前の章では、プロジェクトのディレクトリ構造を理解し、プロジェクトのディレクトリ構造にいくつかの調整を加え、プロジェクトを再度実行することができました。今日は API インターフェース呼び出しツール Axios を構築します。 Vue 自体は ajax 呼び出しをサポートしていません。これらの機能が必要な場合は、対応するツールをインストールする必要があります。
  6. スーパーエージェントやaxiosなど、ajaxリクエストをサポートするツールはたくさんあります。今日は axios を使用します。最近、インターネット上のほとんどのチュートリアル本が axios を使用していると聞いたためです。axios ツール自体は十分に最適化され、カプセル化されていますが、まだ使用が比較的面倒なので、再パッケージ化します。


  7. Axiosツールをインストールします

インストール中、必ずプロジェクトのルートディレクトリに切り替えて、インストールコマンドを実行してください。上記のメッセージが表示されれば、インストールは完了です。 。

Axios ツールをカプセル化します

src/api/index.js ファイルを編集します (前の章でディレクトリ構造を整理したときに、src/api/ ディレクトリに空のindex.js ファイルを作成しました) 、次に、このファイルの内容を入力します。

// 配置API接口地址
var root = 'https://cnodejs.org/api/v1'
// 引用axios
var axios = require('axios')
// 自定义判断元素类型JS
function toType (obj) {
 return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase()
}
// 参数过滤函数
function filterNull (o) {
 for (var key in o) {
  if (o[key] === null) {
   delete o[key]
  }
  if (toType(o[key]) === 'string') {
   o[key] = o[key].trim()
  } else if (toType(o[key]) === 'object') {
   o[key] = filterNull(o[key])
  } else if (toType(o[key]) === 'array') {
   o[key] = filterNull(o[key])
  }
 }
 return o
}
/*
 接口处理函数
 这个函数每个项目都是不一样的,我现在调整的是适用于
 https://cnodejs.org/api/v1 的接口,如果是其他接口
 需要根据接口的参数进行调整。参考说明文档地址:
 https://cnodejs.org/topic/5378720ed6e2d16149fa16bd
 主要是,不同的接口的成功标识和失败提示是不一致的。
 另外,不同的项目的处理方法也是不一致的,这里出错就是简单的alert
*/
function apiAxios (method, url, params, success, failure) {
 if (params) {
  params = filterNull(params)
 }
 axios({
  method: method,
  url: url,
  data: method === 'POST' || method === 'PUT' ? params : null,
  params: method === 'GET' || method === 'DELETE' ? params : null,
  baseURL: root,
  withCredentials: false
 })
 .then(function (res) {
 if (res.data.success === true) {
  if (success) {
   success(res.data)
  }
 } else {
  if (failure) {
   failure(res.data)
  } else {
   window.alert('error: ' + JSON.stringify(res.data))
  }
 }
 })
 .catch(function (err) {
  let res = err.response
  if (err) {
   window.alert('api error, HTTP CODE: ' + res.status)
  }
 })
}
// 返回在vue模板中的调用接口
export default {
 get: function (url, params, success, failure) {
  return apiAxios('GET', url, params, success, failure)
 },
 post: function (url, params, success, failure) {
  return apiAxios('POST', url, params, success, failure)
 },
 put: function (url, params, success, failure) {
  return apiAxios('PUT', url, params, success, failure)
 },
 delete: function (url, params, success, failure) {
  return apiAxios('DELETE', url, params, success, failure)
 }
}
ログイン後にコピー

cnpm install axios -D

Axiosツールの設定

使用する前に、src/main.jsで簡単な設定を行う必要があります。まず元のmain.jsファイルを見てみましょう

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
Vue.config.productionTip = false
/* eslint-disable no-new */
 new Vue({
 el: '#app',
 router,
 template: &#39;<App/>&#39;,
 components: { App }
})
ログイン後にコピー

次のように変更されました:

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from &#39;vue&#39;
import App from &#39;./App&#39;
import router from &#39;./router&#39;
// 引用API文件
import api from &#39;./api/index.js&#39;
// 将API方法绑定到全局
Vue.prototype.$api = api
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
 el: &#39;#app&#39;,
 router,
 template: &#39;<App/>&#39;,
 components: { App }
})
ログイン後にコピー

上記の設定により、プロジェクトで axios ツールを使用できるようになります。 次に、このツールをテストしてみましょう。

Axios ツールの使用

src/page/Index.vue ファイルを変更して、コードを次のコードに調整しましょう:

<template>
 <p>index page</p>
</template>
<script>
export default {
 created () {
  this.$api.get(&#39;topics&#39;, null, r => {
   console.log(r)
  })
 }
}
</script>
ログイン後にコピー

Index.vue でブラウザのコンソールに追加します。インターフェイスによって要求されたデータが同じである場合、インターフェイスの設定が正しく完了していることを意味します。以下に示すように:

私の手順を段階的に実行すれば、最終的な結果は私と同じになるはずです。何か問題がある場合は、コードを注意深く確認してください。 関連する推奨事項:

Vuejs は vue-markdown を使用してコメント メソッドをレンダリングします

Vuejs テクノロジー スタックに関する知識の概要

VueJS の包括的な分析

以上がVueJsを使用したAxiosインターフェースリクエストツールの構築に関する分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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