前端开发:axios在项目中的应用

简介: 前端开发:axios在项目中的应用

用到的模块:

Vue: https://cn.vuejs.org/v2/guide/

Axios: http://www.axios-js.com/zh-cn/docs/

vant: https://youzan.github.io/vant/#/zh-CN/intro


可参考文章

  1. 前端开发:axios在vue中的使用
  2. 前端开发:vant在vue中的使用

1、接口配置

server/contactApi.js

// 统一接口管理
const CONTACT_API = {
    // 获取联系人列表
    getContactList: {
        method: "get",
        url: "/contactList.json"
    }
}


export default CONTACT_API

2、配置全局的Http请求函数

server/http.js

import axios from "axios";

import contactApi from "./contactApi"
import {Toast} from "vant"

let instance = axios.create({
baseURL: "/",
timeout: 1000 // 毫秒
})

// 包装请求方法的容器
const Http = {}

for(let key in contactApi){
let api = contactApi[key]

// async 作用,避免进入回调地狱
Http[key] = async function(data){
let response = {};
try{
response = await instanceapi.method
}catch(err){
response = err;
}
return response;
}
}

// 请求拦截器
instance.interceptors.request.use(
config => {
Toast.loading({
mask: false,
duration: 0, // 一直存在
forbidClick: true, // 禁止点击
message: "加载中..."
})
return config;
},()=>{
Toast.clear()
Toast("请求出错")
}
)

// 添加响应拦截器
instance.interceptors.response.use(
res => {
Toast.clear()
return res.data;
},()=>{
Toast.clear()
Toast("请求出错")
}
)

export default Http

3、全局挂载

main.js


// 把Http挂在到vue实例上,全局可用
Vue.prototype.$Http = Http

4、视图中调用http

views/VantIndex.vue

<template>
<div>
<!-- 联系人列表 -->
<van-contact-list :list="list" />

</div>
</template>

<script>
// 引入组件
import { ContactList } from "vant";

export default {
name: "vantIndex",

data() {
return {
list: []
};
},

// 注册组件
components: {
[ContactList.name]: ContactList
},

methods: {
async getContactList() {
let res = await this.$Http.getContactList({ name: "Tom" });
this.list = res.data;
}
},

// mounted creared
creared() {
this.getContactList();
}
};
</script>

5、修改路由

router.js

routes: [
{
path: '/',
name: 'index',
component: () => import('./views/VantIndex.vue')
}
]

6、测试数据 public/contactList.json

{
"code": 200,
"data": [
{
"name": "张三",
"tel": "13000000000",
"id": 1
},
{
"name": "李四",
"tel": "13000000001",
"id": 2
},
{
"name": "王五",
"tel": "13000000002",
"id": 3
}
]
}

启动服务访问测试

npm run serve

http://localhost:8080/

d21.4.png



            </div>
目录
相关文章
|
12月前
|
Rust JavaScript Java
后端使用的语言是什么?
【10月更文挑战第12天】后端使用的语言是什么?
723 14
|
安全 数据安全/隐私保护 UED
OAuth 2.0 授权码模式的局限性
【10月更文挑战第5天】
198 1
|
存储 图形学 Android开发
Unity——资产包(Asset Bundles)
Unity——资产包(Asset Bundles)
540 0
|
Windows
Windows删除文件时如何取消显示“确认是否删除”的弹窗
本文介绍Windows电脑删除文件时,开启或取消显示确认删除这一提示弹窗的方法~
948 1
Windows删除文件时如何取消显示“确认是否删除”的弹窗
|
算法
【6. 操作系统—虚拟内存管理技术页面置换算法】
**页面置换算法** - 功能与目标 - 实验设置与评价方法 - `局部页面置换算法` - 最优页面置换算法(OPT,optimal) - 先进先出算法(FIFO) - 最近最久未使用算法(LRU,Least Recently Used) - 时钟页面置换算法(Clock) - 最不常用算法(LFU, Least Frequently Used) - Belady现象 - `全局页面置换算法` - 工作集模型 - 工作集页置换算法 - 缺页率置换算法
746 0
【6. 操作系统—虚拟内存管理技术页面置换算法】
|
SQL 弹性计算 人工智能
阿里云云防火墙评测
对阿里云云防火墙进行全面评测
2056 1
阿里云云防火墙评测
|
消息中间件 缓存 弹性计算
丝般顺滑!全新垃圾回收器 ZGC 初体验 | 龙蜥技术
Java 语言的垃圾回收机制(即 GC )是提高 Java 代码开发效率的利器,然而 GC 引发的暂停往往严重影响 Java 业务的响应时间。 本系列共计 3 篇文章,本篇将介绍 GC 的基本概念和 ZGC 的规模化实践,第二篇将介绍 ZGC 的原理和调优,第三篇将介绍 Dragonwell 对于 ZGC 的生产就绪改造。
丝般顺滑!全新垃圾回收器 ZGC 初体验 | 龙蜥技术
|
Linux 机器学习/深度学习 网络协议
Linux存储入门:简易数据恢复方案--分区和LVM实战
以黑箱方式完全依赖工具来进行数据恢复,所需时间和恢复的结果都难以估计。以专家或者专业方式进行数据恢复,技能和成本又太高。那么,数据恢复有没有较为合适的简易方案呢?我们以处理过的实际案例作答。
6739 0
Linux存储入门:简易数据恢复方案--分区和LVM实战
|
新零售 机器学习/深度学习 供应链
【云栖号案例 | 互联网】太平鸟上云 推动中国服饰行业新零售转型
随着国际快时尚品牌进入,中国服饰行业面临产能过剩、前后端供应链管理水平低等问题。上云后实现线上线下一体化全渠道全域运营的数字化变革。
【云栖号案例 | 互联网】太平鸟上云 推动中国服饰行业新零售转型