Vue.js(Axios)

本文介绍了Axios,一个基于Promise的HTTP库,如何在浏览器和Node.js中使用,特别关注在Vue.js中的应用,包括服务端跨域CORS处理和POST请求参数传递的注意事项。
摘要由CSDN通过智能技术生成

Axios

  • 什么是:
    • Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中
  • 何时:
    • 主要用于创建请求
    • 在浏览器中,创建xhr请求; 在node.js中,创建普通http请求
  • 为什么:
    • 浏览器中创建xhr请求: 4种方案:
      • (1)使用原生XHR对象——麻烦
      • (2)使用jQuery的封装函数——大材小用(jQuery中岂止ajax,还包含大量DOM/动画等操作,而Vue只使用ajax,别的都不用。)
      • (3)使用官方提供的VueResource插件——官方废弃
      • (4)使用第三方工具Axios——本身与Vue没任何关系
      • Vue.js生态系统(Ecosystem): Vue.js、Axios、Vue-Router、Vuex、MintUI、ElementUI、Weex…
  • 如何:
    • 1.在HTML页面中引入JS文件
      • <script src="js/axios.min.js"></script>
      • 在全局添加axios对象,包含发送http请求的api
    • 2.调用axios,发起异步请求
      • Get请求:
axios.get(“url”,{ 
    params: {
           //get方式下, 随url发送的参数
    }
}).then(res=>{ … })
  • 服务端跨域CORS
    • 不能用res.send(...)
    • 只能
res.writeHeader(200,{
      "Access-Control-Allow-Origin":"*"
});
res.write(JSON.stringify(result));
res.end();
  • Post请求:
    • axios.post(“url”, “变量=值&变量=值&…”).then()
    • 坑!!!: get和post方法传参时,配置属性名不一样:
      • Get请求传参,用的是params: { } 对象
        Post请求传参,必须用字符串!
    • 解决:
      • 引入qs模块
      • <script src="js/qs.min.js"
    • 使用
      • axios.post(“url”, Qs.stringify({ 参数: 值, 参数: 值, ... })).then()
      • 结果:
        • stringify会将对象转化为queryString语法
    • 坑!!!:获得响应主体的数据: 数据不是直接返回,而是包裹在一个对象的data属性中返回。
      • 无论是get/post方式请求,获得的响应都是一个全新的对象。传统的响应数据,包含在该对象的res.data属性中
      • 所以,res.data,才能获得之前的响应结果
  • 10
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不背完3500个考研英语词汇不改名

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值