Vue 的 axios二次封装

(以下的接口地址链接换成自己的写!!!)

首先在项目中src的目录下创建一个api的文件夹,在api的文件下在穿件两个文件用于二次封装

别忘了先安装axios:(在根目录下安装axios,如果安装过了,就不用看蓝色字体安装过程)

javascript 复制代码
npm install --save axios

然后在main.js中引用axios:

javascript 复制代码
// 引入axios
import {apiGet,apiPost} from './api/api'
Vue.prototype.$apiGet  = apiGet
Vue.prototype.$apiPost = apiPost

api下的第一个api.js:

javascript 复制代码
import axios from 'axios';
 
axios.defaults.timeout = 30000;
// 这个是环境测试配置,不知道可以搜索我的csdn中的Vue测试打包test
axios.defaults.baseURL = process.env.VUE_APP_API_URL

 
// 添加响应拦截器
axios.interceptors.response.use(function (response) {
 
    //可以写if判断,提前拦截错误信息
 
    return response;
 
}, function (err) {
 
    return Promise.reject(err);
});
 
 
export function apiGet(url, params){ 
	return new Promise((resolve, reject) =>{ 
		axios.get(url, { 
			params: params,
			headers:{"token":sessionStorage.getItem('token')}
		}).then(res => {
			resolve(res.data);
		}).catch(err =>{
			reject(err.data) 
		}) 
   });
}
 
 
export function apiPost(url, params){
	return new Promise((resolve, reject) => {
			axios({
				method: 'post',
				url:url,
				data:params
			}).then(res => {
				resolve(res.data);
            }).catch(err =>{reject(err.data)})
        });
    }
 

api下的第二个https.js:

javascript 复制代码
//这个是二次封装(用到apiPost的时候把下面接口那也改成这个,用不到就把apiPost去掉)
import {apiGet,apiPost} from "./api";

export function jindutiao(){
    return new Promise((resolve)=>{
        apiGet("/index.php/index/admin/getNum").then(res=>{
            resolve(res)
})
    });
    // .catch(err=>{
    //     reject(err)
    // })


}

然后按照("jindutiao().这个是https.js中二次封装中你取的函数名字")

先引用:import {jindutiao} from "../api/https"

在使用:jindutiao().then(res=>{

console.log(res);

})

二次封装在页面上的使用以上说的以下示例代码,在script中:

javascript 复制代码
// 这个是二次封装后https.js中封装后直接写函数在这个页面使用
import {jindutiao} from "../api/https"
export default {
    data() {
      return {

      };
    },

    mounted() {

    //    这个是进度条接口
       jindutiao().then(res=>{
            // console.log(res);
            this.percentage = res.data.cssnum;
        this.percentage1 = res.data.htmlnum;
        this.percentage2 = res.data.jsnum;
        this.percentage3 = res.data.vuenum;
        }),

    },
    methods: {


    }
  }
  </script>

如果有跨域问题可以在最后在vue.config.js中添加以下代码解决用注释下面的:

javascript 复制代码
const { defineConfig } = require('@vue/cli-service')
module.exports = defineConfig({
  publicPath:'./',
  transpileDependencies: true,
  lintOnSave:false,


  // 跨域问题
  devServer: {
    proxy:{
      '/api1':{
        target:'http://47.94.4.201/',
        pathRewrite:{'^/api1':''},
        ws:true,
        changeOrigin:true,
      }
    }
  }
})
相关推荐
汪汪大队u12 分钟前
为什么 filter-policy 仅对 ASBR 的出方向生效,且即使在该生效场景下,被过滤的路由在协议内部(如协议数据库)依然存在,没有被彻底移除?
服务器·前端·网络
慧一居士18 分钟前
vue.config.js 文件功能介绍,使用说明,对应完整示例演示
前端·vue.js
颜酱21 分钟前
用导游的例子来理解 Visitor 模式,实现AST 转换
前端·javascript·算法
木易 士心30 分钟前
Nginx 基本使用和高级用法详解
运维·javascript·nginx
蒙特卡洛的随机游走40 分钟前
Spark的宽依赖与窄依赖
大数据·前端·spark
共享家95271 小时前
QT-常用控件(多元素控件)
开发语言·前端·qt
幸运小圣1 小时前
Iterator迭代器 【ES6】
开发语言·javascript·es6
葱头的故事1 小时前
将传给后端的数据转换为以formData的类型传递
开发语言·前端·javascript
中微子1 小时前
🚀 2025前端面试必考:手把手教你搞定自定义右键菜单,告别复制失败的尴尬
javascript·面试
_23331 小时前
vue3二次封装element-plus表格,slot透传,动态slot。
前端·vue.js