详解uniapp项目中如何引入axios

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

详解uniapp项目中如何引入axios

下面uniapp教程栏目给大家介绍一下uniapp项目中引入axios的方法,了解withCredentials允许获取cookie和后端配置的跨域不可同时使用的一些基本知识,希望对大家有所帮助!


安装 axios

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


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

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


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


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


uniapp 项目配置 axios

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


引入 axios

import Vue from 'vue'import axios from 'axios'

登录后复制

配置如下:(注意:withCredentials允许获取cookie 和后端配置的跨域不可同时使用,会报错哦提醒你了!)

import Vue from 'vue'import axios from 'axios'// create an axios instanceconst 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 timeoutcrossDomain: 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进行跨域网络请求,并支持携带cookieaxios.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


// 引入封装后的axiosimport 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


效果图:


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

作者:Sunny_Chen

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

以上就是详解uniapp项目中如何引入axios的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:聊聊Node.js中的events事件模块
下一篇:在Vue应用中使用axios时出现“Uncaught (in promise) Error- Request failed with status code 403”怎么办?

发表评论

关闭广告
关闭广告