当前位置: 首页 > news >正文

Vue电商项目--axios二次封装

postman测试接口

刚刚经过postman工具测试,发现接口果然发生了改变。

新的接口为http://gmall-h5-api.atguigu.cn 

如果服务器返回的数据code字段200,代表服务器返回数据成功

整个项目,接口前缀都有/api字样

axios二次封装 

XmlHttpRequest,fetch,JQ,Axios这些都是很优秀的网络请求库

为什么需要进行二次封装axios?

请求拦截器,响应拦截器:请求拦截器,可以在发请求之前处理一些业务,响应式拦截器:当服务器数据返回以后,可以处理一些事情

首先,我们这个是没有安装axiso,因此要安装一下

安装成功

在项目中经常api文件夹【axios】 

接口当中:路径都带有/api

baseURL:'/api'

意思就是以后如果我们/api/list/card这个路径话,就可以忽略/api。它会自动帮我们添加 

俩个拦截用法。如果不会可以查文档Axios 中文文档 | Axios 中文网 | Axios 是一个基于 promise 的网络请求库,可以用于浏览器和 node.js (axios-http.cn)

统一接口管理 

项目很小:完全可以在组件的生命周期函数中发请求

项目大:axios.get('xxx')

这样写存在一个问题,那就是出现了跨域问题 

而解决跨域问题,可以采用JSONP,CROS,代理

我们这里采用代理方式解决跨域问题

那就是在vue.config.js中配置

// 代理跨域devServer:{proxy:{'/api':{target:'http://gmall-h5-api.atguigu.cn',// pathRewrite:{'^/api':''}}}}

成功解决了跨域的问题 

nprogress进度条的使用

nprogress是一个进度条插件,只要用于页面刷新,显示进度

安装这个插件

npm install nprogress --save

 

看一下我们导入进来的nprogress是什么内容 

 我们可以明显的看到nprogress是一个对象。同时,start表示进度条的开始 done表示进度条的结束

 我们可以在请求拦截器和相应拦截器中设置nprogress设置对应的start和done,但是发现,我们并没有效果。这是因为我们没有引入样式。

 

这就有效果了,但是如果在实际开发。如果要修改这个进度条的颜色

 我们只需要修改它底层的样式就可以了 

http://www.lryc.cn/news/64944.html

相关文章:

  • 人生四维度
  • Python 调用 MessageBeep 播放系统音效
  • 废物,我TMD一个985却斗不过专科生(大厂自动化测试2年被裁)
  • p70 内网安全-域横向内网漫游 Socks 代理隧道技术(NPS、FRP、CFS 三层内网漫游)
  • 第三十二章 Unity Mecanim动画系统(上)
  • 第二章 集合
  • 这一篇Databinding应该可以帮助迅速上手吧
  • 【PHP在线定制商城网站源码V3.0】开源的DIY在线定制商城系统+在线礼品定制
  • cout源码浅析
  • 发送Ajax get请求详解
  • SQL语句
  • Mysql 学习(八)单表查询方法二
  • 安卓系统下的截屏和录屏
  • 行为型模式-中介者模式
  • 辅助驾驶功能开发-功能规范篇(16)-2-领航辅助系统NAP-功能ODD定义
  • PMP/高项 06-项目成本管理
  • XXL-JOB中间件【实现分布式任务调度】
  • Vue3+Element Plus环境搭建和一键切换明暗主题的配置
  • Leetcode326. 3 的幂
  • 【运动规划算法项目实战】如何在栅格地图中实现Dijkstra算法
  • 【算法】一文彻底搞懂ZAB算法
  • 【软考高级】2022年系统分析师综合知识
  • 关于AI未来的思考和应用场景
  • 智慧城市规划数字化管理:数字孪生技术的创新应用
  • 开心档之C++ 指针
  • 零基础搭建私人影音媒体平台【远程访问Jellyfin播放器】
  • Abstract Expressionist
  • 【郭东白架构课 模块二:创造价值】24|节点四:如何减少语义上的分歧?
  • windows下免费本地部署类ChatGpt的国产ChatGLM-6B
  • flask+opencv+实时滤镜(原图、黑白、怀旧、素描)