【vue2项目总结】——接口配置

简介: 【vue2项目总结】——接口配置

@[toc]

响应拦截器统一配置

响应拦截器是咱们拿到数据的 第一个 “数据流转站”,可以在里面统一处理错误,只要不是 200 默认给提示,抛出错误
utils/request.js

import {
   
    Toast } from 'vant'

...

// 添加响应拦截器
request.interceptors.response.use(function (response) {
   
   
  const res = response.data
  if (res.status !== 200) {
   
   
    Toast(res.message)
    return Promise.reject(res.message)
  }
  // 对响应数据做点什么
  return res
}, function (error) {
   
   
  // 对响应错误做点什么
  return Promise.reject(error)
})

axios封装

将 axios 请求方法,封装到 request 模块**

1.安装 axios

npm i axios

2.新建 utils/request.js 封装 axios 模块
利用 axios.create 创建一个自定义的 axios 来使用

/* 封装axios用于发送请求 */
import axios from 'axios'

// 创建一个新的axios实例
const request = axios.create({
   
   
  baseURL: 'http://cba.itlike.com/public/index.php?s=/api/',
  timeout: 5000
})

// 添加请求拦截器
request.interceptors.request.use(function (config) {
   
   
  // 在发送请求之前做些什么
  return config
}, function (error) {
   
   
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
request.interceptors.response.use(function (response) {
   
   
  // 对响应数据做点什么
  return response.data
}, function (error) {
   
   
  // 对响应错误做点什么
  return Promise.reject(error)
})

export default request

添加请求 loading 效果

1.请求时,打开 loading

// 添加请求拦截器
request.interceptors.request.use(function (config) {
   
   
  // 在发送请求之前做些什么
  Toast.loading({
   
   
    message: '请求中...',
    forbidClick: true,
    loadingType: 'spinner',
    duration: 0
  })
  return config
}, function (error) {
   
   
  // 对请求错误做些什么
  return Promise.reject(error)
})

2.响应时,关闭 loading

// 添加响应拦截器
request.interceptors.response.use(function (response) {
   
   
  const res = response.data
  if (res.status !== 200) {
   
   
    Toast(res.message)
    return Promise.reject(res.message)
  } else {
   
   
    // 清除 loading 中的效果
    Toast.clear()
  }
  // 对响应数据做点什么
  return res
}, function (error) {
   
   
  // 对响应错误做点什么
  return Promise.reject(error)
})

封装api接口

1.将请求封装成方法,统一存放到 api 模块,与页面分离
2.具体实现
新建 api/login.js 提供获取图形验证码 Api 函数

图形验证码的接口

import request from '@/utils/request'

// 获取图形验证码
export const getPicCode = () => {
   
   
  return request.get('/captcha/image')
}

login/index.vue页面中调用测试

async getPicCode () {
   
   
  const {
   
    data: {
   
    base64, key } } = await getPicCode()
  this.picUrl = base64
  this.picKey = key
},
async created () {
   
   
  this.getPicCode()
},
data () {
   
   
  return {
   
   
    picUrl: '',
    picKey: ''
  }
},
methods: {
   
   
  // 获取图形验证码
  async getPicCode () {
   
   
    const {
   
    data: {
   
    base64, key } } = await request.get('/captcha/image')
    this.picUrl = base64
    this.picKey = key
  }
}

create方法,在页面还未渲染成html前,调用函数,从后端获取数据,在实现对页面的数据进行显示

短信验证码的接口

export const getMsgCode = (captchaCode, captchaKey, mobile) => {
   
   
  return request.post('/captcha/sendSmsCaptcha', {
   
   
    form: {
   
   
      captchaCode,
      captchaKey,
      mobile
    }
  })
}
 await getMsgCode(this.picCode, this.picKey, this.mobile)

若是有参数的后端接口,在调用时这样传递参数

总结

在这里插入图片描述
在登录的组件中,data里存着需要用到的数据,方便使用
在这里插入图片描述
生命周期钩子,页面未渲染前就获得后端数据
在这里插入图片描述
定义方法,用异步
在这里插入图片描述
实现双向绑定,相当于input+value

目录
相关文章
|
2天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的销售项目流程化管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的销售项目流程化管理系统附带文章源码部署视频讲解等
17 3
|
2天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的项目申报管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的项目申报管理系统附带文章源码部署视频讲解等
16 3
|
10天前
|
JavaScript 前端开发 开发者
vue3+ts配置跨域报错问题解决:> newpro2@0.1.0 serve > vue-cli-service serve ERROR Invalid options in vue.
【6月更文挑战第3天】在 Vue CLI 项目中遇到 "ERROR Invalid options in vue.config.js: ‘server’ is not allowed" 错误是因为尝试在 `vue.config.js` 中使用不被支持的 `server` 选项。正确配置开发服务器(如代理)应使用 `devServer` 对象,例如设置代理到 `http://xxx.com/`: ```javascript module.exports = { devServer: {
24 1
|
21小时前
|
JavaScript 前端开发 测试技术
使用 Vue CLI 脚手架生成 Vue 项目
通过 Vue CLI 创建 Vue 项目可以极大地提高开发效率。它不仅提供了一整套标准化的项目结构,还集成了常用的开发工具和配置,使得开发者可以专注于业务逻辑的实现,而不需要花费大量时间在项目配置上。
53 7
使用 Vue CLI 脚手架生成 Vue 项目
|
2天前
|
JSON JavaScript 前端开发
在Vue3项目中,Vite起到的作用及其可以做的事情
Vite是Vue 3项目的关键快速开发服务器和高效的热模块替换(HMR)。它的亮点包括:使用ES模块实现快速启动和动态加载,模块级别HMR提升开发效率,Rollup打包优化生产构建。此外,Vite还支持插件系统、自定义配置、静态资源处理和现代JS特性。通过`npm create vite`可快速搭建Vue项目,配置文件`vite.config.js`可定制行为,`.env`文件管理环境变量。Vite优化了开发与构建流程,提高开发者效率并保证构建性能。
|
2天前
|
JavaScript 算法
“Error: error:0308010C:digital envelope routines::unsupported”启动vue项目遇到一个错误【已解决
“Error: error:0308010C:digital envelope routines::unsupported”启动vue项目遇到一个错误【已解决
8 1
|
3天前
|
JavaScript 前端开发 Java
【vue实战项目】通用管理系统:作业列表
【vue实战项目】通用管理系统:作业列表
16 0
|
3天前
|
JavaScript API
【vue实战项目】通用管理系统:信息列表,信息的编辑和删除
【vue实战项目】通用管理系统:信息列表,信息的编辑和删除
21 2
|
3天前
|
JavaScript 前端开发 API
【vue实战项目】通用管理系统:学生列表
【vue实战项目】通用管理系统:学生列表
16 2
|
3天前
|
缓存 JavaScript
【vue实战项目】通用管理系统:首页
【vue实战项目】通用管理系统:首页
11 2