vue:axios二次封装,接口统一存放、封装jsonp+promise

您所在的位置:网站首页 axios使用jsonp vue:axios二次封装,接口统一存放、封装jsonp+promise

vue:axios二次封装,接口统一存放、封装jsonp+promise

2022-05-29 03:55| 来源: 网络整理| 查看: 265

基于框架:vue

一、基于http库:axios

基本用法:

1.通过node安装:npm install axios

  2. 在项目目录的src文件夹下新建apis文件夹,在该文件夹内新建index.js文件,内容如下代码块:

对接口设置拦截器

img_b3b8f7b7401cacea5a7d1821b251aba7.png img_0edea129ee68327294f103d2c31149f4.png

接口请求数据

img_7ecd529425cb95a6b1e6cb186073d76d.png

接着要在src目录下边创建一个store文件,然后在文件里边创建一个actions.js文件和index.js文件

在actions.js文件里边对请求数据进行封装

img_007e06f52358a3e9810c55c56238a6e8.png

在index.js文件引入actions.js文件,并在main.js文件下边引入store下边的index.js文件并将store暴露出去

img_80434fc189ce27bdc0c18cfc64d0d089.png

二、jsonp原理

通过动态创建标签,src指向数据地址,其中callback参数作为函数的名来包裹住JSON数据返回客户端,也就是说,只要服务端提供的js脚本是动态生成的就行了,这样调用者可以传一个参数告诉服务端“我想要一段xx函数的js代码,请你返回给我”,于是服务器就可以按照客户的需求来生成js脚本并响应了。

安装:jsonp  npm install jsonp

安装qs  npm install qs (由于的jsonp请求都是get请求,所以引入qs)

在需要请求接口的文件引入jsonp

img_e259ff4aab6ee1690428f910d4d493c8.png

首先查看携带大参数及参数格式

img_3d2a5e9b1f4370265a1697c81b53d4a8.png

对参数和jsonp请求做封装

img_d4687d96ba0c611fbf78d1e347f492d4.png

调用上边的函数

img_45c1fba75a2aebecee05d3839f97e007.png

以上当服务端返回的数据是jsonp格式的时候,vue中可以使用jsonp插件来处理。

目前在自己的项目组件化中使用,有写的不对的地方欢迎大家留言指出~



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3