ホームページ  >  記事  >  ウェブフロントエンド  >  axios を使用して Ajax リクエストを実装する方法 (詳細なチュートリアル)

axios を使用して Ajax リクエストを実装する方法 (詳細なチュートリアル)

亚连
亚连オリジナル
2018-06-19 16:09:071859ブラウズ

以前、jQuery による最もエレガントな ajax リクエストの作成方法について紹介しました。この記事では主に、axios の高度な実践と、最もエレガントな ajax リクエストの作成方法に関する関連情報を紹介します。サンプルコードは非常に詳細であり、あらゆる人の学習や仕事に一定の参考と学習価値をもたらします。必要な方は以下を参照してください。

はじめに

ajax についてはあまり紹介する必要はないと思いますが、設定によって解決できる問題はハードコーディングすべきではないと私は強く信じています。以下ではあまり触れません。詳しい紹介を見てください。

姉妹記事 jQuery Advanced: 最もエレガントな方法で ajax リクエストを作成する

axios は Vue によって公式に推奨されている ajax ライブラリであり、vue-resource の置き換えに使用されます。詳細な基本知識については、この記事を参照してください: //www.jb51.net/article/109444.htm

利点:

  • Ajax インターフェイスを追加するには、さらに数行記述するだけで済みます。以上です

  • コンポーネントに axios 呼び出しを記述する必要はありません。API メソッドを直接呼び出すだけで、非常に便利です

  • インターフェースが調整されている場合は、変更するだけで済みますインターフェース設定ファイル

  • インターフェース設定の一元管理

1.コンテンツタイプの設定

// filename: content-type.js
module.exports = {
 formData: 'application/x-www-form-urlencoded; charset=UTF-8',
 json: 'application/json; charset=UTF-8'
}

3.のメソッド

// filename: api-sdk-conf.js
import contentType from './content-type'
export default {
 baseURL: 'http://192.168.40.231:30412',
 apis: [
 {
  name: 'login',
  path: '/api/security/login?{{id}}',
  method: 'post',
  contentType: contentType.formData,
  status: {
  401: '用户名或者密码错误'
  }
 }
 ]
}

4.

// request.js
import axios from 'axios'
import qs from 'qs'
import contentType from '@/config/content-type'
import apiConf from '@/config/api-sdk-conf'
var api = {}
// render 函数用来渲染路径上的变量, 算是一个微型的模板渲染工具
// 例如render('/{{userId}}/{{type}}/{{query}}', {userId:1,type:2, query:3})
// 会被渲染成 /1/2/3
function render (tpl, data) {
 var re = /{{([^}]+)?}}/
 var match = ''
 while ((match = re.exec(tpl))) {
 tpl = tpl.replace(match[0], data[match[1]])
 }
 return tpl
}
// fire中的this, 会动态绑定到每个接口上
function fire (query = {}, payload = '') {
 // qs 特别处理 formData类型的数据
 if (this.contentType === contentType.formData) {
 payload = qs.stringify(payload)
 } 
 // 直接返回axios实例,方便调用then,或者catch方法
 return axios({
 method: this.method,
 url: render(this.url, query),
 data: payload,
 headers: {
  contentType: this.contentType
 }
 })
}
apiConf.apis.forEach((item) => {
 api[item.name] = {
 url: apiConf.baseURL + item.path,
 method: item.method,
 status: item.status,
 contentType: item.contentType,
 fire: fire
 }
})
export default api

ブラウザの結果を使用します:

import api from '@/apis/request'
...
  api.login.fire({id: '?heiheihei'}, {
  username: 'admin',
  password: 'admin',
  namespace: '_system'
  })
...
理解できないことがあります。答え

ログインメソッドだけが必要なコンポーネントの場合ですが、このように書くとエラーが発生します。

Request URL:http://192.168.40.231:30412/api/security/login??heiheihei
Request Method:POST
Status Code:200 OK
Remote Address:192.168.40.231:30412
Referrer Policy:no-referrer-when-downgrade
POST /api/security/login??heiheihei HTTP/1.1
Host: 192.168.40.231:30412
Connection: keep-alive
Content-Length: 47
Accept: application/json, text/plain, */*
Origin: http://localhost:8080
contentType: application/x-www-form-urlencoded; charset=UTF-8
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36
Content-Type: application/x-www-form-urlencoded
Referer: http://localhost:8080/
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
username=admin&password=admin&namespace=_system
このように書く前提は、request.jsの最後に

import {login} from '@/apis/request'

を書くことですが、これは望ましくありません、なぜならインターフェースが追加されるたびにここでエクスポートする必要があるからです。オープンクローズの原則に従ってください。もっと良い方法はありますか? 上記は私があなたのためにまとめたものです。 関連記事:

nodejsを使用したgulpパッケージングの実装方法

Angular5.1の新機能の詳細な解釈

vuexを使用してメニュー管理を実装する方法

以上がaxios を使用して Ajax リクエストを実装する方法 (詳細なチュートリアル)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。