vue axios的二次封装

第一步:在当前根目录下打开终端 

                下载axios   npm install axios  -S

      (1)在main.js中引入axios

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

import 'lib-flexible/flexible'
import axios from 'axios'


Vue.config.keyCodes.enter = 13
Vue.config.productionTip = false
Vue.prototype.axios = axios

new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')

第二步:新建一个vue.config.js文件

module.exports = {
  devServer: {
    proxy: {
      "/api": {
        target: 'http://www.ibugthree.com/', // 想要访问接口域名
        changeOrigin: true, // 开启跨域,在本地创建一个虚拟服务,然后发送请求的数据,并同时接收请求的数据,这样服务端和服务端进行数据交互就不会有问题
        pathRewrite: {
          "^/api": '', // 利用这个地面的值拼接上target里面的地址
        }
      }
    }
  },
}

第三步:在src文件夹下新建api

3.1:api里新建request.js文件夹  里面写入:

// 这是axios二次封装
import axios from 'axios'
 
//定义一个延迟数据
let timeout=3000
 
export const Service=axios.create({
    timeout:timeout,//延迟时间
    method:'POST',
    headers:{
        "content-Type":"application/x-www-form-urlencoded", //post 必须写这个
        "pc-token": "4a82b23dbbf3b23fd8aa291076e660ec", //后端提供
    }
});
 
 
// 请求拦截
Service.interceptors.request.use(config=>{
    console.log("请求拦截")
    return config;
})
 
 
// 响应拦截
Service.interceptors.response.use(response=>{
    console.log("响应拦截")
    //返回数据
    return response.data
},err=>{
    console.log(err)
})

3.2:api文件夹里面新建index.js 写入:

import { Service} from "./request";
 
// 车辆搜索
export function searchCar(config){
    let params=new URLSearchParams()
    params.append("page",config.page)
    params.append("mod",config.mod)
    return Service({
        url:'/api/oldcar/searchCar',
        method:'post',
        data:params
    })
}
 
// 车辆搜索关键词
export function searchList(config){
    let params=new URLSearchParams()
    params.append("page",config.page)
    params.append("mod",config.mod)
    return Service({
        url:'/api/oldcar/searchList',
        method:'post',
        data:params
    })
}

第四步:在需要的页面 .vue里面引入使用

//引入axios
import { searchCar } from "@/api";
 
export default {
  async created() {
    const data = await searchCar({ page: 1, mod: "宝马" });
    console.log(data);
  },
}

也可以把它封装为一个方法调用

        async的用法,它作为一个关键字放到函数前面,用于表示函数是一个异步函数,因为async就是异步的意思, 异步函数也就意味着该函数的执行不会阻塞后面代码的执行。

 
methods:{
 // 封装一个方法
    async searchCarAsync() {
      try {
        const data = await searchCar({ page: 2, mod: "奔驰" });
        console.log(data);
        //这是循环添加到数组  data里面定义一个数组添加到里面循环页面
        for (var i = 0; i < data.length; i++) {
          this.carList.push(data[i]);
        }
      } catch (error) {
        console.error("@searchCarAsync:", error);
      }
    },
},
//这里可以调用一下
 created() {
    this.searchCarAsync();
 },

try catch:自己处理异常

try{
        可能出现异常的代码

}catch(异常类名A  e){
        如果出现了异常类A类型的异常,那么执行该代码

}....(catch可以有多个)

finally{
        最终肯定必须要执行的代码(例如释放资源的代码)

}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 是一个前端框架,而 axios 是一个基于 Promise 的 HTTP 请求库。在 Vue 项目中,我们通常需要使用 axios 来进行接口请求。由于每个项目的接口返回数据结构和请求方式可能不同,因此我们需要对 axios 进行二次封装以方便统一管理。 二次封装可以解决以下问题: 1. 统一处理请求错误,例如网络错误、接口返回的错误码等。 2. 统一处理请求 loading 状态,避免每个请求都需要手动设置 loading 状态。 3. 统一处理请求头和请求参数等信息,避免每个请求都需要手动设置。 以下是一个简单的 vue axios 二次封装的示例: ``` // api.js import axios from 'axios' import { Message } from 'element-ui' const service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, timeout: 5000 // 请求超时时间 }) // 请求拦截器 service.interceptors.request.use( config => { // 在这里可以统一设置请求头等信息 return config }, error => { // 请求错误时的处理 return Promise.reject(error) } ) // 响应拦截器 service.interceptors.response.use( response => { const res = response.data // 在这里可以统一处理接口返回的错误码等信息 if (res.code !== 0) { Message({ message: res.message || 'Error', type: 'error', duration: 5 * 1000 }) return Promise.reject(new Error(res.message || 'Error')) } else { return res } }, error => { // 响应错误时的处理 return Promise.reject(error) } ) export default service ``` 上述代码中,我们通过 axios.create 创建了一个 axios 实例,并对其进行了配置。在请求拦截器中,我们可以统一设置请求头等信息。在响应拦截器中,我们可以统一处理接口返回的错误码等信息,并使用 element-ui 中的 Message 组件来显示错误信息。 使用示例: ``` import request from '@/utils/api' request({ url: '/user/info', method: 'get', params: { id: 123 } }).then(response => { console.log(response) }).catch(error => { console.log(error) }) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值