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

简介: 基于框架:vue一、基于http库:axios基本用法:1.通过node安装:npm install axios  2. 在项目目录的src文件夹下新建apis文件夹,在该文件夹内新建index.

基于框架: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原理

通过动态创建<script>标签,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插件来处理。

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

相关文章
|
3月前
|
资源调度 JavaScript 前端开发
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
这篇文章是关于如何在Vue项目中使用axios进行网络请求、二次封装axios以及使用mockjs模拟响应数据的教程。
105 1
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
|
4月前
封装axios的get、post方法
本文介绍了如何封装axios的get和post方法,并展示了具体的代码实现,包括使用axios创建实例、设置请求拦截器以及定义get和post函数。
148 2
|
3月前
vue3 + Ts 中 使用 class 封装 axios
【10月更文挑战第8天】
177 1
|
3月前
vue3 + Ts 中 使用 class 封装 axios
【10月更文挑战第5天】
226 1
|
3月前
|
前端开发 JavaScript API
自己动手封装axios通用方法并上传至私有npm仓库:详细步骤与实现指南
自己动手封装axios通用方法并上传至私有npm仓库:详细步骤与实现指南
137 0
|
5月前
|
JSON JavaScript 前端开发
【Vue面试题二十四】、Vue项目中有封装过axios吗?主要是封装哪方面的?
这篇文章讨论了在Vue项目中封装axios的最佳实践,包括设置接口请求前缀、请求头、状态码、请求方法的封装,以及如何使用请求和响应拦截器来处理token和响应状态,从而简化HTTP请求的配置和错误处理,提高代码的可维护性。
【Vue面试题二十四】、Vue项目中有封装过axios吗?主要是封装哪方面的?
|
3月前
|
JavaScript API 开发工具
vue尚品汇商城项目-day02【11.对axios二次封装+12.接口统一管理】
vue尚品汇商城项目-day02【11.对axios二次封装+12.接口统一管理】
39 0
|
6月前
|
存储 开发框架 前端开发
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
基于SqlSugar的开发框架循序渐进介绍(10)-- 利用axios组件的封装,实现对后端API数据的访问和基类的统一封装处理
|
6月前
|
前端开发 JavaScript
Vue 中 Promise 的then方法异步使用及async/await 异步使用总结
Vue 中 Promise 的then方法异步使用及async/await 异步使用总结
183 1
|
5月前
|
前端开发 JavaScript
VUE——Uncaught (in promise) TypeError: Cannot read property '__esModule' of undefined
VUE——Uncaught (in promise) TypeError: Cannot read property '__esModule' of undefined
109 0