ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

axios 简单封装

2022-01-11 03:31:42  阅读:156  来源: 互联网

标签:Toast axios return error 封装 token 简单 import


参考文档:https://www.cnblogs.com/deng-jie/p/12420873.html

                   https://juejin.cn/post/6844903652881072141

创建一个http.js文件

import axios from "axios"
import { Toast } from 'vant';

// 环境的切换
if (process.env.NODE_ENV == 'development') {
    axios.defaults.baseURL = 'https://uniapp-toutiao.herokuapp.com/';
} else if (process.env.NODE_ENV == 'debug') {
    axios.defaults.baseURL = 'https://uniapp-toutiao.herokuapp.com/';
} else if (process.env.NODE_ENV == 'production') {
    axios.defaults.baseURL = 'https://uniapp-toutiao.herokuapp.com/';
}
// 请求超时时间
axios.defaults.timeout = 2000
//post请求头   application/json;charset=UTF-8
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';

// 请求拦截器
axios.interceptors.request.use(function (config) {
    // 请求的时候加个toke,存在就加上
    let token = window.localStorage.getItem("token")
    if (token) {
        config.headers.token = token
        //也可以这种写法
        // config.headers['token'] = token;
    }
    Toast.loading({
        message: '请求中...',
        forbidClick: true,
        duration: 0,
    });
    return config;
}, function (error) {
    // Do something with request error
    Toast.fail('请求失败!');

    return Promise.reject(error);
});

// 响应拦截器
axios.interceptors.response.use(function (response) {
    //判断下相应过来的状态码,这里根据后端怎么写响应码有关
    Toast.clear();

    return response;
}, function (error) {
    //判断响应错误码
    // if (error.response.status) {
    //     switch (error.response.status) {
    //         case 401:
    //             console.log(401)
    //             break
    //         case 403:
    //             console.log(403)
    //             break
    //         case 404:
    //             console.log(404)
    //             break
    //         default:
    //             Toast({
    //                 message: '默认响应错误码',
    //                 duration: 1500,
    //                 forbidClick: true
    //             });


    //     }
    // }
    Toast.fail("服务器连接失败");
    return Promise.reject(error);
});

//通用方法
export const GET = (url, params) => {
    return axios.get(url, params)
}
export const POST = (url, params) => {
    return axios.post(url, { params: params }).then(
        res => {
            console.log(res.data)
        }
    )
}

在main.js中引入

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import Vant from 'vant';
import 'vant/lib/index.css';
import "./http"
import { GET, POST } from './http';

Vue.prototype.postRequest  = POST
Vue.prototype.getRequest  = GET


Vue.use(Vant);
Vue.config.productionTip = false

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

使用案例

<template>
  <div>
    <van-button @click="jay" type="primary">主要按钮</van-button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      url: "https://uniapp-toutiao.herokuapp.com/api/profiles/home_tab_list",
      url2:"api/profiles/home_tab_list"
    };
  },
  methods: {
    jay() {

 
      this.getRequest(this.url2).then(
       res=>{
        console.log(res.data);
       }
      )

    },
  },
};
</script>

<style lang="scss" scoped>
</style>

  

标签:Toast,axios,return,error,封装,token,简单,import
来源: https://www.cnblogs.com/jayy520/p/15786731.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有