亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

VueJs 搭建Axios接口請求工具

2019-11-19 14:54:16
字體:
來源:轉載
供稿:網友

axios 簡介

axios 是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端,它本身具有以下特征:

  1. 從瀏覽器中創建 XMLHttpRequest
  2. 從 node.js 發出 http 請求
  3. 支持 Promise API
  4. 攔截請求和響應
  5. 轉換請求和響應數據
  6. 取消請求
  7. 自動轉換JSON數據
  8. 客戶端支持防止 CSRF/XSRF

上一章,我們認識了項目的目錄結構,以及對項目的目錄結構做了一些調整,已經能把項目重新跑起來了。今天我們來搭建api接口調用工具Axios。Vue本身是不支持ajax調用的,如果你需要這些功能就需要安裝對應的工具。

支持ajax請求的工具很多,像superagent和axios。今天我們用的就是axios,因為聽說最近網上大部分的教程書籍都使用的是axios,本身axios這個工具就已經做了很好的優化和封裝,但是在使用時,還是比較繁瑣,所以我們來重新封裝一下。

安裝Axios工具

cnpm install axios -D 

在安裝的時候,一定要切換進入咱們的項目根目錄,再運行安裝命令,然后如提示以上信息,則表示安裝完成。

封裝Axios工具

編輯src/api/index.js文件(我們在上一章整理目錄結構時,在src/api/目錄新建了一個空的index.js文件),現在我們為該文件填寫內容。

// 配置API接口地址var root = 'https://cnodejs.org/api/v1'// 引用axiosvar axios = require('axios')// 自定義判斷元素類型JSfunction 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) }}

更多關于AxIos的解釋請參見:https://github.com/mzabriskie/axios

配置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: '<App/>', 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 'vue'import App from './App'import router from './router'// 引用API文件import api from './api/index.js'// 將API方法綁定到全局Vue.prototype.$api = apiVue.config.productionTip = false/* eslint-disable no-new */new Vue({ el: '#app', router, template: '<App/>', components: { App }})

通過以上的配置,我們就可以在項目中使用axios工具了,接下來我們來測試一下這個工具。

使用Axios工具

我們來修改一下 src/page/Index.vue 文件,將代碼調整為以下代碼:

<template> <div>index page</div></template><script>export default { created () {  this.$api.get('topics', null, r => {   console.log(r)  }) }}</script>

我們在Index.vue中向瀏覽器的控制臺輸入一些接口請求到的數據,如果你和我也一樣,那說明我們的接口配置完成正確。如下圖:

如果你是按我的操作一步一步來,那最終結果應該和我一樣。如果出錯請仔細檢查代碼。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品福利在线看| 久久久精品中文字幕| 久久中文精品视频| 国产精品人成电影| 国产精品h片在线播放| 日韩欧美国产骚| 日韩av大片免费看| 国产高清视频一区三区| 国产视频久久久| 亚洲一区中文字幕| 国产精品扒开腿做爽爽爽男男| 成人综合网网址| 激情成人在线视频| 国产一级揄自揄精品视频| 日本精品中文字幕| 国产成人福利视频| 亚洲欧美制服第一页| 国产精品视频大全| 久久九九精品99国产精品| 成人h视频在线| 美女扒开尿口让男人操亚洲视频网站| 久久久久久久一| 秋霞av国产精品一区| 成人免费自拍视频| 中文字幕日韩在线播放| 久久99热精品这里久久精品| 亚洲精品久久久久久久久久久久| 77777亚洲午夜久久多人| 欧美一级高清免费播放| 国产精品一区专区欧美日韩| 91精品国产网站| 欧美超级免费视 在线| 亚洲欧洲黄色网| 国产精品激情av在线播放| 国外成人免费在线播放| 亚洲欧美另类在线观看| www欧美xxxx| 国产精品嫩草影院一区二区| 日韩欧美在线国产| 一区二区国产精品视频| 97色伦亚洲国产| 成人久久18免费网站图片| 欧美成人精品在线播放| 欧美日韩国产色| 97涩涩爰在线观看亚洲| 久久久久久国产精品| 久久亚洲精品一区二区| 久久久极品av| 国产精品黄色影片导航在线观看| 精品久久久免费| 最近2019免费中文字幕视频三| 久久精品国产69国产精品亚洲| 国产精品美女主播在线观看纯欲| 国产精品久久久久久久久久尿| 欧美日韩亚洲精品一区二区三区| 美女性感视频久久久| 国产精品久久久久久久久久久新郎| 国产精品入口日韩视频大尺度| 91精品国产99久久久久久| 69久久夜色精品国产69乱青草| 亚洲国产天堂久久综合网| 国产精品爱久久久久久久| 日韩欧美有码在线| 欧美精品中文字幕一区| 久久精品99久久香蕉国产色戒| 国产区亚洲区欧美区| 亚洲欧洲成视频免费观看| 成人h视频在线观看播放| 亚洲人成电影网站色| 国产精自产拍久久久久久| 久久成人人人人精品欧| 欧美激情一区二区三区高清视频| 欧美日韩国产页| 中文字幕一区二区精品| 91久久综合亚洲鲁鲁五月天| 日韩a**中文字幕| 亚洲人成毛片在线播放| 国模精品系列视频| 亚洲护士老师的毛茸茸最新章节| 欧美激情欧美狂野欧美精品| 欧美成人在线网站| 亚洲精品一区久久久久久| 黑人巨大精品欧美一区二区免费| 久久久噜噜噜久久| 亚洲国产精品久久91精品| 欧美理论电影在线观看| 亚洲欧美日韩国产中文专区| 992tv在线成人免费观看| 国产91色在线|免| 原创国产精品91| 国产精品久久久久久久午夜| 亚洲精品中文字幕av| 亚洲国产91精品在线观看| 国产精品一久久香蕉国产线看观看| 在线看福利67194| 91av在线视频观看| 最近2019中文字幕一页二页| 日韩欧美在线视频| 欧美成人手机在线| 亚洲毛片在线免费观看| 亚洲一区精品电影| 亚洲精品免费av| 欧美在线精品免播放器视频| 亚洲欧美一区二区精品久久久| 成人一区二区电影| 欧美亚洲激情在线| 亚洲三级av在线| 日本精品一区二区三区在线播放视频| 成人国产精品免费视频| 国产精品久久久久久久久久东京| 精品国产一区二区三区久久狼黑人| 日韩av大片在线| 亚洲毛片在线看| 国产成人高清激情视频在线观看| 日韩亚洲欧美成人| 亚洲国产97在线精品一区| 97在线观看视频| 日本韩国在线不卡| 日韩精品在线观看一区| 青青草国产精品一区二区| 久久久久久久电影一区| 国产精品黄页免费高清在线观看| 亚洲欧美另类国产| 日本国产一区二区三区| 国内久久久精品| 国产视频999| 久久久免费av| 另类专区欧美制服同性| 国产三级精品网站| 亚洲男女自偷自拍图片另类| 8x拔播拔播x8国产精品| 高清欧美一区二区三区| 国产日产欧美精品| 欧美成在线视频| 欧美亚洲国产精品| 久久久久久久久综合| 这里只有精品丝袜| 亚洲精品免费网站| 日韩亚洲欧美成人| 国产亚洲激情视频在线| 亚洲大胆人体av| 亚洲女人初尝黑人巨大| 在线播放精品一区二区三区| 亚洲精品videossex少妇| 91在线|亚洲| 国产精品夜间视频香蕉| 中文字幕亚洲色图| 国产在线观看一区二区三区| 亚洲一区二区久久久久久久| 欧美日韩国产色视频| 欧美肥臀大乳一区二区免费视频| 秋霞成人午夜鲁丝一区二区三区| 国产啪精品视频网站| 亚洲国产精品国自产拍av秋霞| 国产精品一二三视频| 亚洲欧美成人在线| 亚洲第一在线视频| 69精品小视频| 国产精品美女网站| 欧美性高跟鞋xxxxhd| 岛国视频午夜一区免费在线观看| 久久深夜福利免费观看| 伊人久久五月天| 欧美wwwwww|