使用vue简单的封装axios

没有什么难度,一看基本上就能懂,其实和普通axios也差不了多少。只不过就是可以自由一些,可以使用自己想要的名字去请求接口,也相对可以省下一些代码。

1.首先创建文件夹,在文件夹中创建 Api.js和http.js(名称可以随自己更改)

2. 在http.js中引入axios 并创建拦截器

import axios from "axios";
// import { ElLoading, ElMessage } from "element-plus";
 
let http = axios.create({
  baseURL: "",
  // timeout: 1000,
});
 
 
// mock拦截
let loadingInstance;
 
// 拦截器的添加
http.interceptors.request.use(
  (config) => {
    // loadingInstance = ElLoading.service("加载中");
    return config;
  },
  (err) => {
    loadingInstance?.close();
    // ElMessage.error("网络异常");
    return Promise.reject(err);
  }
);
 
//响应拦截器
http.interceptors.response.use(
  (res) => {
    loadingInstance?.close();
    return res.data;
  },
  (err) => {
    loadingInstance?.close();
    // ElMessage.error("请求失败");
    return Promise.reject(err);
  }
);
export default http;

3.在Api.js中引入http.js,并写如自己封装的方法


import http from "./http.js";
export default {
//custom这个名字可以随意修改,没必要非得是custom
  custom(data,port,way) {
    // console.log('接收数据',data,port,way);
    return http({
      url: port,
      method: way,
      data:data,
    });
  },
}

4.在需要用到的页面中引入Api.js


import Api from "../api/Api";
export default {
  data() {
    return {
      list: [],
    };
  },
  created() {
    let that = this;
    Api.custom({ id: 1 }, "输入自己需要的url域名", "post")
      .then((res) => {
        that.list = res.sciencelist;
        console.log(res,"自定义");
      });
  },

5.最后请求结果:

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3 中封装 Axios 并全局使用的步骤如下: 1. 安装 Axios 首先,需要安装 Axios: ``` npm install axios ``` 2. 封装 Axios 在 src 目录下创建一个 api 目录,并在该目录下创建一个 axios.js 文件,用于封装 Axios: ```javascript import axios from 'axios' const instance = axios.create({ baseURL: 'https://api.example.com', }) export default instance ``` 在上面的代码中,我们使用 `axios.create()` 方法创建了一个 Axios 实例,并设置了基础 URL。 接下来,我们可以添加请求拦截器和响应拦截器: ```javascript import axios from 'axios' const instance = axios.create({ baseURL: 'https://api.example.com', }) instance.interceptors.request.use( (config) => { // 在请求发送之前做些什么 return config }, (error) => { // 对请求错误做些什么 return Promise.reject(error) } ) instance.interceptors.response.use( (response) => { // 对响应数据做些什么 return response }, (error) => { // 对响应错误做些什么 return Promise.reject(error) } ) export default instance ``` 在上面的代码中,我们使用 `instance.interceptors.request.use()` 方法添加了一个请求拦截器,用于在请求发送之前对请求进行处理。同时,我们还使用 `instance.interceptors.response.use()` 方法添加了一个响应拦截器,用于对响应进行处理。 3. 全局使用 Axios 在 main.js 文件中,将 Axios 注册为全局插件,以便在整个应用程序中使用: ```javascript import { createApp } from 'vue' import App from './App.vue' import axios from './api/axios' const app = createApp(App) app.config.globalProperties.$http = axios app.mount('#app') ``` 在上面的代码中,我们在 Vue 的全局配置中添加了一个 `$http` 属性,并将 Axios 实例赋值给它。这样,在组件中就可以使用 `$http` 进行请求了: ```javascript export default { methods: { fetchData() { this.$http.get('/data').then((response) => { // 处理响应 }) }, }, } ``` 这就是在 Vue 3 中封装 Axios 并全局使用的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值