兴国资源网 Design By www.nnzcdc.com
前言
如今,在项目中,普遍采用Axios库进行Http接口请求。它是基于promise的http库,可运行在浏览器端和node.js中。此外还有拦截请求和响应、转换JSON数据、客户端防御XSRF等优秀的特性。
考虑到各个项目实际使用时写法混乱,不统一。对Axios进行一下通用化的封装,目的是帮助简化代码和利于后期的更新维护,尽量通用化。
方法如下
1. vue安装axios
npm install axios -S 或者 npm i axios -S
2. 在main.js进行全局引入
import axios from 'axios' Vue.prototype.$axios = axios //将axios绑定到vue的原型上
3. 配置跨域 在根目录下vue.config.js里边
module.exports = { publicPath: './', //配置跨域请求 devServer: { open: true, //是否自动打开浏览器 https: false, //是否开启https hotOnly: false, proxy: { // 配置跨域 '/api': { target: 'http://********', //请求接口域名 ws: true, secure: false, changOrigin: true, //是否允许跨越 pathRewrite: { '^/api': '' } } }, before: app => { } } }
4. 在src子目录下的api文件夹下创建api.js文件进行简单的封装axios
import axios from 'axios' //这里引用了element的loading全屏加载 import { Loading } from "element-ui"; const service = axios.create({ baseURL: '/', timeout: 30000 // 设置请求超时时间 }) let loading = ""; // 请求拦截器 service.interceptors.request.use( (config) => { // 在请求发送之前做一些处理 if (!(config.headers['Content-Type'])) { loading = Loading.service({ lock: true, text: "加载中...", spinner: "el-icon-loading", background: "rgba(255,255,255,0.7)", customClass: "request-loading", }); if (config.method == 'post') { config.headers['Content-Type'] = 'application/json;charset=UTF-8' for (var key in config.data) { if (config.data[key] === '') { delete config.data[key] } } config.data = JSON.stringify(config.data) } else { config.headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8' config.data = JSON.stringify(config.data) } } const token = "token" // 让每个请求携带token-- ['X-Token']为自定义key 请根据实际情况自行修改 if (token) { config.headers['Authorization'] = token } return config }, (error) => { loading.close(); // 发送失败 console.log(error) return Promise.reject(error) } ) // 响应拦截器 service.interceptors.response.use( (response) => { loading.close(); // dataAxios 是 axios 返回数据中的 data // loadingInstance.close(); const dataAxios = response.data // 这个状态码是和后端约定的 return dataAxios }, (error) => { return Promise.reject(error) } ) export default service
5. 在api文件夹下创建http文件
// 引入封装好的axios // ps:如果没有封装,正常引入axios即可 import axios from "./api"; // /api为配置跨域的路径变量 let reportUpload= '/api/report/upload' export const Upload= () => { return axios.get( reportUpload ) }
6. 在页面中调用接口
// 引入封装好的接口 import { Upload} from "@/api/http.js"; // 调用时使用 async Upload() { let { result } = await getlist (); console.log(result) },
总结
兴国资源网 Design By www.nnzcdc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
兴国资源网 Design By www.nnzcdc.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年05月07日
2024年05月07日
- 田震《永远执着 田震20周年纪念精选 2CD》[WAV+CUE][1.3GB]
- 【民族融合】VA-2024-TheOrientCollective:SpaceTribe(FLAC)
- 林友仁-《雪夜闻钟》(2013)[FLAC+CUE]
- KOKIA-Wheretogomylove_(2013Remaster2014)[24bit96kHzFLAC]
- ABC唱片-《监听耳机天碟》6N纯银镀膜[WAV+CUE]
- ABC唱片-《正毒.超强人声测试发烧碟片》6N纯银镀膜[WAV+CUE]
- ABC唱片-《彭修文.一代巨人》6N纯银镀膜[WAV+CUE]
- ABC唱片-《木村好夫.860万吉他》6N纯银镀膜[WAV+CUE]
- ABC唱片-《马克柯贝.我至爱你大提琴》6N纯银镀膜[WAV+CUE]
- 云水谣《小调江南2·西湖情思》APE+CUE
- 蔡琴《精选-梦中人 人声试音典范 4CD》[WAV+CUE][1.9GB]
- 群星《妙音纪念珍藏版贰》[WAV+CUE][650MB]
- 群星《宝丽金摘金宝典 3CD》[WAV+CUE][1.9GB]
- 中唱《好歌珍藏--明月寄情》500首经典优美旋律30CD[WAV]
- 【古典音乐】卡拉扬《首次录音(6)》2006[FLAC+CUE整轨