当前位置:Gxlcms > JavaScript > axios异步请求数据的使用(代码示例)

axios异步请求数据的使用(代码示例)

时间:2021-07-01 10:21:17 帮助过:78人阅读

本篇文章给大家带来的内容是关于axios异步请求数据的使用(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

使用Mock模拟好后端数据之后,就需要尝试请求加载数据了。数据请求选择了axios,现在都推荐使用axios。

axios(https://github.com/axios/axios)是基于 promise 的 HTTP 库。如官网文档介绍,npm i 之后,在需要的组件中加载就可以了。个人认为,编码的魅力在于,解决问题的方法不止一种,有时候这个方法在你的开发环境下ok,在我的开发环境下却不ok,所以,问题是各式各样的,而解决问题的方法也是百花齐放的。

axios的入门

1、安装

  1. npm i axios -S

2、引入

在src目录下新建apis.js文件(项目逐渐完善的过程中会有很有个api接口,当然也可以命名为axios.js,命名是为了让别人看懂),并引入:

  1. import axios from 'axios';

之后,编辑apis.js文件,考虑封装axios.get或post请求

3、apis.js文件的编辑

  1. import axios from 'axios';
  2. const Domain = "http://localhost:8080"; // 定义根域名
  3. axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; // 设置post默认的请求头
  4. // 封装 post 请求
  5. export function post(action, params){
  6. return new Promise((resolve, reject) => {
  7. // url 判断是测试环境 就要拿 测试环境的域名, 正式环境的就要用 正式域名
  8. let url = Domain + action;
  9. axios.post(url, params)
  10. .then(response => {
  11. resolve(response.data)
  12. })
  13. .catch(error => {
  14. reject(error)
  15. })
  16. });
  17. }
  18. // 封装 get 请求
  19. export function get(action, params){
  20. return new Promise((resolve, reject) => {
  21. axios.get(Domain + action, params)
  22. .then(response => {
  23. resolve(response.data)
  24. })
  25. .catch(error => {
  26. reject(error)
  27. })
  28. });
  29. }
  30. export default {
  31. postData(action, params){
  32. return post(action, params)
  33. },
  34. getData(action, params){
  35. return get(action, params)
  36. }
  37. }

4、在需要的组件中进行引用

  1. import api from '../../apis.js';
  2. export default {
  3. name: "banner",
  4. data() {
  5. return {
  6. bannerList: []
  7. };
  8. },
  9. created(){
  10. this.getBanner(); // 在页面渲染完成即加载
  11. },
  12. methods: {
  13. getBanner(){
  14. this.$api.getData('/getBanner').then(val => {
  15. this.bannerList = val.imgs;
  16. });
  17. }
  18. }
  19. }

5、全局配置axios

很多组件都需要请求数据,每用一次导入一次很麻烦,全局配置之后就不用在组件中导入了。

  1. 在入口文件main.js中引入,之后挂在vue的原型链上:
  2. import api from './apis.js';
  3. Vue.prototype.$http = api;
  4. 在组件中使用:
  5. getBanner(){
  6. this.$http.getData('/getBanner').then(val => {
  7. this.bannerList = val.imgs;
  8. });
  9. }

6、axios结合vuex(在项目中还没用到,如果有问题,欢迎指正)

在vuex的仓库文件store.js中引用,使用action添加方法。action 可以包含异步操作,而且可以通过 action 来提交 mutations。action有一个固有参数context,但是 context 是 state 的父级,包含state、getters

  1. import Vue from 'Vue'
  2. import Vuex from 'vuex'
  3. import axios from 'axios'
  4. Vue.use(Vuex)
  5. export default new Vuex.Store({
  6. // 定义状态
  7. state: {
  8. banners: {
  9. name: 'pic'
  10. }
  11. },
  12. actions: {
  13. // 封装一个 ajax 方法
  14. saveBanner (context) {
  15. axios({
  16. method: 'get',
  17. url: '/getBanner',
  18. data: context.state.banners
  19. })
  20. }
  21. }
  22. })

在组件中发送请求的时候,需要使用 this.$store.dispatch 来分发

  1. methods: {
  2. getBananer() {
  3. this.$store.dispatch('saveBanner') // actions里的方法名
  4. }
  5. }

异步加载的几种方法

1、$.ajax( url[, settings])

url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址。
type: 要求为String类型的参数,请求方式(post或get)默认为get。
data:规定要发送到服务器的数据。
async:布尔值,表示请求是否异步处理。默认是 true。
dataType: 要求为String类型的参数,预期服务器返回的数据类型。
contentType:要求为String类型的参数,当发送信息至服务器时,内容编码类型默认为"application/x-www-form-urlencoded"。
success:要求为Function类型的参数,请求成功后调用的回调函数。
error:Function类型的参数,请求失败后调用的回调函数。
jsonp:在一个 jsonp 中重写回调函数的字符串。

  1. $(function(){
  2. $('#send').click(function(){
  3. $.ajax({
  4. type: "GET",
  5. url: "test.json",
  6. data: {username:$("#username").val(), content:$("#content").val()},
  7. dataType: "json",
  8. success: function(data){
  9. // handle success
  10. }
  11. error: function(data){
  12. // handle error
  13. }
  14. jsonp: ""
  15. });
  16. });
  17. });

2、$.ajax 的跨域请求问题

当Ajax请求的url不是本地或者同一个服务器的地址时,浏览器会报一个错误:No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin…………由于浏览器的安全机制,不能调用不同服务器下的url地址。基于此,jQuery.ajax给出了jsonp的解决方案: 把服务器返回的数据类型设置为jsonp。

  1. $(function(){
  2. $('#send').click(function(){
  3. $.ajax({
  4. type: "GET",
  5. url: "test.json",
  6. data: {username:$("#username").val(), content:$("#content").val()},
  7. dataType: "jsonp", // jsonp格式
  8. success: function(data){
  9. // handle success
  10. }
  11. error: function(data){
  12. // handle error
  13. }
  14. jsonp: "callback"
  15. });
  16. });
  17. });

但是,jsonp是一种非官方的方法,而且这种方法只支持get请求,不如post请求安全。此外,jsonp需要服务器配合,如果是访问的是第三方服务器,我们没有修改服务器的权限,那么这种方式是不可行的。

3、vue框架中的vue-resource

ue-resource是Vue.js的一款插件,它可以通过XMLHttpRequest或JSONP发起请求并处理响应。vue-resource体积小,支持主流浏览器。不过,vue2.0之后就不再更新了,尤大神推荐使用axios。

  1. {
  2. // GET /someUrl
  3. this.$http.get('/someUrl').then(response => {
  4. // get body data
  5. this.someData = response.body;
  6. }, response => {
  7. // error callback
  8. });
  9. }

4、vue-resource的跨域请求问题

同样地,由于浏览器的安全机制,vue-resource也面临着跨域请求的问题。解决方案如下:在vue项目下的 config/index.js 文件里面配置代理proxyTable:

  1. dev: {
  2. // Paths
  3. assetsSubDirectory: 'static',
  4. assetsPublicPath: '/',
  5. proxyTable: { // 新增,解决跨域请求问题
  6. '/api': {
  7. target: 'http://192.168.1.103:8080/',
  8. changeOrigin: true,
  9. pathRewrite: {
  10. '`/api': '/'
  11. }
  12. },
  13. secure: false
  14. },
  15. target中写你想要请求数据的地址的域名

4、axios跨域请求的问题

与vue-resource一样,在vue项目下的 config/index.js 文件里面配置代理proxyTable:

  1. dev: {
  2. // Paths
  3. assetsSubDirectory: 'static',
  4. assetsPublicPath: '/',
  5. proxyTable: { // 新增,解决跨域请求问题
  6. '/api': {
  7. target: 'http://192.168.1.103:8080/',
  8. changeOrigin: true,
  9. pathRewrite: {
  10. '`/api': '/'
  11. }
  12. },
  13. secure: false
  14. },

不过vue-resource和axios这两个方法,可能配置了代理proxyTable还是会报:No 'Access-Control-Allow-Origin' header is present on ……的问题,这需要后端服务器配合设置:

  1. header("Access-Control-Allow-Origin", "*");
  2. header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");

以上就是axios异步请求数据的使用(代码示例)的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行