详解uniapp项目中如何引入axios

发布时间:2022-05-23 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了详解uniapp项目中如何引入axios脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
下面uniapp教程栏目给大家介绍一下uniapp项目中引入axios的方法,了解wIThCredentials允许获取cookie和后端配置的跨域不可同时使用的一些基本知识,希望对大家有所帮助

详解uniapp项目中如何引入axios

安装 axios

1、首先检查是否安装 npm 工具:工具 --> 插件安装

详解uniapp项目中如何引入axios

2、检查是否安装 npm,如果没有可以去看我的这篇文章:windows安装node.js用npm安装vue

3、安装后在当前目录下打开内置终端:(和前几步一样检查插件安装与否)

详解uniapp项目中如何引入axios

4、在终端输入:npm install axios 安装 axios

详解uniapp项目中如何引入axios

5、安装后如下所示:(node_modules 出现 axios)

详解uniapp项目中如何引入axios

uniapp 项目配置 axios

  • 创建 utils 文件按自己所需创建 .js 文件

    详解uniapp项目中如何引入axios


  • 引入 axios

  • @H_126_93@
    import Vue From 'vue'
    import axios from 'axios'
    • 配置如下:(注意:withCredentials允许获取cookie 和后端配置的跨域不可同时使用,会报错哦提醒你了!)

    import Vue from 'vue'
    import axios from 'axios'
    
    // create an axios instance
    const service = axios.create({
    	baseURL: 'https://www.yongjiachen.top/jccrm', // url = base url + request url
    	//withCredentials: true, // send cookies when cross-domain requests 注意:withCredentials和后端配置的cross跨域不可同时使用
    	timeout: 6000, // request timeout
    	croSSDomain: true
    })
    
    // request拦截器,在请求之前做一些处理
    service.interceptors.request.use(
        config => {
            // if (Store.state.token) {
            //     // 给请求头添加user-token
            //     config.headers["user-token"] = store.state.token;
            // }
            console.LOG('请求拦截成功')
            return config;
        },
        error => {
            console.log(error); // for debug
            return PRomise.reject(error);
        }
    ); 
    
    //配置成功后的拦截器
    service.interceptors.response.use(res => {
        if (res.data.status== 200) {
            return res.data
        } else {
            return Promise.reject(res.data.msg);
        }
    }, error => {
    	if (error.response.status) {
    		switch (error.response.status) {
    			case 401:
    				break;
    			default:
    				break;
    		}
    	}
        return Promise.reject(error)
    })
    
    
    // 在main.js中放入这段自定义适配器的代码,就可以实现uniapp的app和小程序开发中能使用axios进行跨域网络请求,并支持携带cookie
    axios.defaults.adapter = function(config) { 
        return new Promise((resolve, reject) => {
            console.log(config)
            VAR seTTLe = require('axios/lib/core/settle');
            var buildURL = require('axios/lib/helPErs/buildURL');
            uni.request({
                method: config.method.toUpperCase(),
                url: config.baseURL + buildURL(config.url, config.params, config.paramsSerializer),
                header: config.headers,
                data: config.data,
                dataType: config.dataType,
                responseType: config.responseType,
                sslVerify: config.sslVerify,
                complete: function complete(response) {
                    console.log("执行完成:",response)
                    response = {
                        data: response.data,
                        status: response.statusCode,
                        errMsg: response.errMsg,
                        header: response.header,
                        config: config
                    };
    
                    settle(resolve, reject, response);
                }
            })
        })
    }
    
    export default service
    • 在项目根目录的 main.js 配置引入全局 axios

      详解uniapp项目中如何引入axios

    // 引入封装后的axios
    import axios from './utils/request/request.js'
    /**
     * 给Vue函数添加一个原型属性$axios 指向Axios
     * 这样做的好处是在vue实例或组件中不用再去重复引用Axios 直接用this.$axios就能执行axios 方法了
     * 在.vue中使用,this.$axios.get
     * @param {Object} config
     */
    Vue.prototype.$axios = axios
    • 愉快的使用 axios

      详解uniapp项目中如何引入axios

    • 效果图:

      详解uniapp项目中如何引入axios

    原文地址:https://juejin.cn/post/7005042333288759333

    作者:Sunny_Chen

    更多编程相关知识,请访问:编程视频!!

    以上就是详解uniapp项目中如何引入axios的详细内容,更多请关注脚本宝典其它相关文章!

    脚本宝典总结

    以上是脚本宝典为你收集整理的详解uniapp项目中如何引入axios全部内容,希望文章能够帮你解决详解uniapp项目中如何引入axios所遇到的问题。

    如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

    本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
    如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:uniapp