资讯专栏INFORMATION COLUMN

axios异步请求数据的简单使用

forsigner / 822人阅读

摘要:使用模拟好后端数据之后模拟数据的使用参考,就需要尝试请求加载数据了。数据请求选择了,现在都推荐使用。规定要发送到服务器的数据。布尔值,表示请求是否异步处理。要求为类型的参数,请求成功后调用的回调函数。在一个中重写回调函数的字符串。

使用Mock模拟好后端数据之后(Mock模拟数据的使用参考:https://segmentfault.com/a/11...),就需要尝试请求加载数据了。数据请求选择了axios,现在都推荐使用axios。

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

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

import axios from "axios";

之后,编辑apis.js文件,考虑封装axios.get或post请求
3、apis.js文件的编辑
import axios from "axios";
const Domain = "http://localhost:8080";  // 定义根域名
axios.defaults.headers.post["Content-Type"] = "application/x-www-form-urlencoded"; // 设置post提交数据的格式

// 封装 post 请求
export function post(action, params){
  return new Promise((resolve, reject) => {
    // url 判断是测试环境 就要拿 测试环境的域名, 正式环境的就要用 正式域名
    let url = Domain + action;
    axios.post(url, params)
      .then(response => {
        resolve(response.data)
      })
      .catch(error => {
        reject(error)
      })
  });
}

 // 封装 get 请求

export function get(action, params){
  return new Promise((resolve, reject) => {
    axios.get(Domain + action, params)
      .then(response => {
        resolve(response.data)
      })
      .catch(error => {
        reject(error)
      })
  });
}

export default {
  postData(action, params){
    return post(action, params)
  },
  getData(action, params){
    return get(action, params)
  }
}
4、在需要的组件中进行引用
 import api from "../../apis.js";
 export default {
  name: "banner",
  data() {
    return {
      bannerList: []
    };
  },
  created(){
    this.getBanner(); // 在页面渲染完成即加载
  },
  methods: {
    getBanner(){
      this.$api.getData("/getBanner").then(val => {
        this.bannerList = val.imgs;
      });
    }
  }
}
5、全局配置axios

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

在入口文件main.js中引入,之后挂在vue的原型链上:

import api from "./apis.js";
Vue.prototype.$http = api;

在组件中使用:

getBanner(){
    this.$http.getData("/getBanner").then(val => {
      this.bannerList = val.imgs;
    });
  }
  
6、axios结合vuex(在项目中还没用到,如果有问题,欢迎指正)

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

import Vue from "Vue"
import Vuex from "vuex"
import axios from "axios"

Vue.use(Vuex)
export default new Vuex.Store({
 // 定义状态
  state: {
    banners: {
      name: "pic"
    }
  },
  actions: {
    // 封装一个 ajax 方法
    saveBanner (context) {
      axios({
        method: "get",
        url: "/getBanner",
        data: context.state.banners
      })
    }
  }
})

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

methods: {
  getBananer() {
  this.$store.dispatch("saveBanner")  // actions里的方法名
  }
}

  
异步加载的几种方法 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 中重写回调函数的字符串。

$(function(){
  $("#send").click(function(){
    $.ajax({
      type: "GET",
      url: "test.json",
      data: {username:$("#username").val(), content:$("#content").val()},
      dataType: "json",
      success: function(data){
        // handle success
      }
      error: function(data){
       // handle error
      }
      jsonp: ""
     });
   });
 });
 
2、$.ajax 的跨域请求问题

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

 $(function(){
  $("#send").click(function(){
    $.ajax({
      type: "GET",
      url: "test.json",
      data: {username:$("#username").val(), content:$("#content").val()},
      dataType: "jsonp",   // jsonp格式
      success: function(data){
        // handle success
      }
      error: function(data){
       // handle error
      }
      jsonp: "callback"
     });
   });
 });
 

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

3、vue框架中的vue-resource

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

{
   // GET /someUrl
  this.$http.get("/someUrl").then(response => {
   // get body data
  this.someData = response.body;
 }, response => {
   // error callback
 });
}

全局配置post提交数据的格式:

Vue.http.options.emulateJSON = true;

全局配置根路径:

Vue.http.options.root = "http://localhost:8080";
4、vue-resource的跨域请求问题

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

dev: {
    // Paths
    assetsSubDirectory: "static",
    assetsPublicPath: "/",
    proxyTable: {    // 新增,解决跨域请求问题
      "/api": {
        target: "http://192.168.1.103:8080/",
        changeOrigin: true,
        pathRewrite: {
          "`/api": "/"
        }
      },
      secure: false
    },
    
 target中写你想要请求数据的地址的域名
 
4、axios跨域请求的问题

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

 dev: {
    // Paths
    assetsSubDirectory: "static",
    assetsPublicPath: "/",
    proxyTable: {    // 新增,解决跨域请求问题
      "/api": {
        target: "http://192.168.1.103:8080/",
        changeOrigin: true,
        pathRewrite: {
          "`/api": "/"
        }
      },
      secure: false
    },
    

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

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

emmmm,总感觉自己还是有点懵 233

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/100965.html

相关文章

  • JavaScript中发出HTTP请求最常用方法

    摘要:在本文中,我们将介绍一些在中发出请求的流行方法。是发出异步请求的传统方式。如果等于,则表示请求已完成。是进行调用的最简单方法之一。它需要三个参数请求的地址您要发送的数据和回调函数。事实上,这是制作请求的最佳和最喜欢的方式之一。 showImg(https://segmentfault.com/img/bVbdEhE?w=749&h=450);JavaScript具有很好的模块和方法来发...

    kyanag 评论0 收藏0
  • JavaScript中发出HTTP请求最常用方法

    摘要:在本文中,我们将介绍一些在中发出请求的流行方法。是发出异步请求的传统方式。如果等于,则表示请求已完成。是进行调用的最简单方法之一。它需要三个参数请求的地址您要发送的数据和回调函数。事实上,这是制作请求的最佳和最喜欢的方式之一。 showImg(https://segmentfault.com/img/bVbdEhE?w=749&h=450);JavaScript具有很好的模块和方法来发...

    gougoujiang 评论0 收藏0
  • 浅谈中断在异步事件中作用

    摘要:在日常开发中,我们经常会用到与后台进行数据交互,异步请求的情况一般分为两种,小量数据下的一次性请求与大量数据下的连续或并发请求,这篇文章介绍的就是中断在大量连续请求的情况下的作用和必要性。当第一个请求完成后,第二个或者其他的请求并没有完成。 在日常开发中,我们经常会用到ajax与后台进行数据交互,异步请求的情况一般分为两种,小量数据下的一次性请求与大量数据下的连续或并发请求,这篇文章介...

    Cristic 评论0 收藏0
  • Axios源码深度剖析 - AJAX新王者

    摘要:我们先来看看构造函数构造函数就是用来实现拦截器的,这个构造函数原型上有个方法。关于源码,其实是比较简单的,都是用来操作该构造函数的实例属性的。存放拦截器方法,数组内每一项都是有两个属性的对象,两个属性分别对应成功和失败后执行的函数。 Axios源码分析 - XHR篇 文章源码托管在github上,欢迎fork指正! axios 是一个基于 Promise 的http请求库,可以用在浏览...

    DangoSky 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<