【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 数据可视化
vue-cli学习一:vue脚手架的 vue-cli2和vue-cli3版本 创建vue项目,vue的初始化详解
这篇文章介绍了如何使用vue-cli 2和3版本来创建Vue项目,并详细说明了两者之间的主要区别。
98 5
vue-cli学习一:vue脚手架的 vue-cli2和vue-cli3版本 创建vue项目,vue的初始化详解
|
2月前
|
JavaScript 容器
乾坤qiankun框架搭建 主应用为vue3的项目。
乾坤qiankun框架搭建 主应用为vue3的项目。
166 2
|
2月前
|
JavaScript
Vue CLi脚手架创建第一个VUE项目
Vue CLi脚手架创建第一个VUE项目
36 3
|
1月前
|
数据采集 监控 JavaScript
在 Vue 项目中使用预渲染技术
【10月更文挑战第23天】在 Vue 项目中使用预渲染技术是提升 SEO 效果的有效途径之一。通过选择合适的预渲染工具,正确配置和运行预渲染操作,结合其他 SEO 策略,可以实现更好的搜索引擎优化效果。同时,需要不断地监控和优化预渲染效果,以适应不断变化的搜索引擎环境和用户需求。
|
25天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
2月前
|
JavaScript 数据可视化
vue-cli学习二:vue-cli3版本 创建vue项目后,Runtime-Compiler和Runtime-only两个模式详解;vue项目管理器;配置文件的配置在哪,以及如何配置
这篇文章详细介绍了Vue CLI 3版本创建项目时的Runtime-Compiler和Runtime-only两种模式的区别、Vue程序的运行过程、render函数的使用、eslint的关闭方法,以及Vue CLI 2和3版本配置文件的不同和脚手架3版本创建项目的配置文件配置方法。
71 3
vue-cli学习二:vue-cli3版本 创建vue项目后,Runtime-Compiler和Runtime-only两个模式详解;vue项目管理器;配置文件的配置在哪,以及如何配置
|
1月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
386 4
|
2月前
|
JavaScript
如何在 Vue 项目中选择合适的模块格式
【10月更文挑战第20天】选择合适的模块格式需要综合考虑多个因素,没有一种绝对正确的选择。需要根据项目的具体情况进行权衡和分析。在实际选择过程中,要保持灵活性,根据项目的发展和变化适时调整模块格式。
21 7
|
1月前
Vue3 项目的 setup 函数
【10月更文挑战第23天】setup` 函数是 Vue3 中非常重要的一个概念,掌握它的使用方法对于开发高效、灵活的 Vue3 组件至关重要。通过不断的实践和探索,你将能够更好地利用 `setup` 函数来构建优秀的 Vue3 项目。
|
2月前
|
JavaScript 前端开发 编译器
在 Vue 项目中使用 ES 模块格式的优点
【10月更文挑战第20天】在 Vue 项目中使用 ES 模块格式具有众多优点,这些优点共同作用,使得项目能够更高效、更可靠地开发和运行。当然,在实际应用中,还需要根据项目的具体情况和需求进行合理的选择和配置。
37 6