axios也是一个JS库,我们今天要说的是使用axios来进行我们的Ajax请求

那么问题来了,我们为什么要放着jQuery不用,用axios呢?

因为这个JS库是专门用于网络数据请求的库,它有着俩个优点:相比于原生XMLHttpRequest对象毋庸置疑它非常的简洁方便;相比于jQuery更加的小(文件轻量),更加的专业专一(专注网络数据请求)

和jQuery相同,都有get请求方式,post请求以及在函数内部指定请求三种方式来请求Ajax

我们通过代码和请求状况来入门axios:

目录

一.GET请求:

二.POST请求:

请求成功:​

三.内部请求:


一.GET请求:

我们调用axios方法发起请求后的返回值是一个Promise对象,也就是说返回值res不是一个真正的数据

const btn1 = document.querySelector('#button1')btn1.addEventListener('click',function(){//请求地址const url = "http://www.XXXXXXXX/api/get"//URL中的查询参数const pObj = {name:"小蜗",age:22}axios.get(url,{params:pObj}).then(function(res){console.log(res.data)})})//ES6新语法(解构赋值)
const btn1 = document.querySelector('#button1')btn1.addEventListener('click',async function(){//请求地址const url = "http://www.XXXXXXXX/api/get"//URL中的查询参数const pObj = {name:"小蜗",age:22}const {data : res} = await axios.get(url,{params:pObj})console.log(res.data)})

二.POST请求:

const btn2 = document.querySelector('#button2')btn2.addEventListener('click',function(){const url = "http://www.XXXXXXXXXX/api/post"const obj = {name:"小蜗",age:22}axios.post(url,{data:obj}).then(function(res){console.log(res.data)})})//或者我们post请求不需要去书写data,直接在对象中写入数据就可以了
const btn2 = document.querySelector('#button2')btn2.addEventListener('click',function(){const url = "http://www.XXXXXXXXXX/api/post"const obj = {name:"小蜗",age:22}axios.post(url,{obj}).then(function(res){console.log(res.data)})})//ES6新语法(解构赋值)
const btn2 = document.querySelector('#button2')btn2.addEventListener('click',async function(){const url = "http://www.XXXXXXXXXX/api/post"const obj = {name:"小蜗",age:22}const {data : res} = await axios.post(url,{obj})console.log(res.data)})

请求成功:


三.内部请求:

axios({

method:'请求的类型post/get',

url:'URL',

data:{

post数据(get请求没有data)

},

params:{

get参数(post没有params)

        }

}).then(回调函数)

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="https://unpkg.com/axios/dist/axios.min.js"></script>
</head>
<body><div id="app"><button>点击发起POST请求</button></div><script>const btn = document.querySelector('button')btn.addEventListener('click',function(){axios({method:'POST',url:'http://www.XXXXXXXXXX',data:{name:'小蜗',age:22}}).then(function(res){console.log(res.data);})})</script>
</body>
</html>

因为axios的返回值是一个promise对象,所以我们还可以使用await搭配async得到值 :

const btn = document.querySelector('button')
btn.addEventListener('click',async function(){const res = axios({method:'POST',url:'http://www.XXXXXXXXXX',data:{name:'小蜗',age:22}})console.log(res)
})

 tips:如果调用某个方法的返回值是promise对象,那么我们就可以在前面使用await

如果我们使用了await的话,还需要使用async来修饰方法

我们可以使用解构赋值来得到数据:

const btn = document.querySelector('button')
btn.addEventListener('click',async function(){const {data} = await axios({method:'POST',url:'http://www.XXXXXXXXX',data:{name:'小蜗',age:22}})console.log(data)
})

如果我们想要直接获取到数据条,可以data.data来获取到,但是这样不便利于阅读,所以我们可以使用:res来将解构出来的data重命名为res,使用res.data来获取输出数据

const btn = document.querySelector('button')
btn.addEventListener('click',async function(){const {data : res} = await axios({method:'GET',url:'http://www.liulongbin.top:3006/api/getbooks'})console.log(res.data)
})

更多请参考官方文档: axios中文文档|axios中文网 | axios欢迎使用 axios,本文档将帮助您快速上手。(troubleshooting.html) 中的解答, 什么是 axios?Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。 axios Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中。 特性 从浏览器中创建 XMLHttpRequests 从 nodehttp://www.axios-js.com/zh-cn/docs/

jQuery ? NO, Axios——请求数据相关推荐

  1. Cli4.5.x 中使用axios请求数据

    Cli4.5.x 中使用axios请求数据 文章目录 Cli4.5.x 中使用axios请求数据 前言 一.安装并配置axios 1.安装axios 2.vue-axios 二.各种请求方法 三.请求 ...

  2. Vue之单文件组件的数据传递,axios请求数据及路由router

    1.传递数据 例如,我们希望把父组件的数据传递给子组件. 可以通过props属性来进行传递. 传递数据三个步骤: 步骤1:在父组件中,调用子组件的组名处,使用属性值的方式往下传递数据 <Menu ...

  3. ajax type是get请求,jQuery的Ajax请求数据时type无法使用GET

    写一个ASP.NET MVC例子,它是使用jQuery的$.Ajax来呼叫控制器的数据. 创建一个视图: 运行结果: 一切正常,但是本例子我们只是获取数据,并没有做任何数据POST上传至控制器,我们尝 ...

  4. vue中使用axios请求数据过程

    使用axios请求数据过程 1. 导入axios包 import axios from 'axios' 2. 在钩子函数中调用函数 mounted() {this.getinitialdata() / ...

  5. 前端Vue学习之路(四)axios请求数据

    axios 1.增加新知识 2.旧方案 3.新方案(一) 4.为什么要用拦截器 (新方案二) 1.增加新知识 假如每个组件都引用axios,后期如果axios库不再维护了,那每个组件都要改动 所以封装 ...

  6. Vue3 配置代理和使用全局axios请求数据

    更详细请参考: https://blog.csdn.net/qq_28550263/article/details/120633610 vue3中配置全局代理和使用axios向服务器请求数据 main ...

  7. 今天试着用原生axios以及jquery下的axios请求数据

    axios.get("https://route.showapi.com/9-2", {params: {area: "北京",showapi_appid: & ...

  8. 偏前端 - vue-cli(axios请求数据==》token+按接口参数顺序(参数值拼接base64)- MD5)...

    token+按接口参数顺序(参数值拼接base64)-> MD5) 请教于"喵咪",再此特别鸣谢!~ 特别强调:import qs from qs; 这个内部方法一定要用哦. ...

  9. axios请求数据和拦截

    mounted () {     #//注册     this.axios.post(' http://localhost:3000/register',{       username:'laoch ...

最新文章

  1. Codeforces 895C - Square Subsets
  2. 研究人员探索gaze fixation对基于运动想象的脑机接口性能的影响
  3. dd命令测试linux磁盘io情况,【LINUX】正确的使用dd进行磁盘读写速度测试
  4. AS3.0第一个实例:(Hello World)
  5. HTML 元素内部添加预加载
  6. 计算机分数的简便运算,分数的简便运算和分数的解方程
  7. handler机制的原理_Handler机制竟然可以这样解释,我惊呆了!
  8. 【完结】深度学习CV算法工程师从入门到初级面试有多远,大概是25篇文章的距离...
  9. QML 可以多选ComboBox的实现
  10. element-ui的input加单位符号
  11. 代码-JS之淡入淡出背景自动切换
  12. 使用HTML5里的classList操作CSS类
  13. java编程用什么文本编辑器_编程必备,程序员应该都知道的7款文本编辑器
  14. iOS 手势识别(点按、长按、轻扫)
  15. 汽车故障诊断技术【3】
  16. 求助文,缺少stubs-n32_hard.h
  17. 【开发管理类软件必备知识视频教程之一】登录窗体前台注意事项
  18. 新闻分析:微软到底需要雅虎什么?
  19. java 判断图片格式_Java判断上传图片格式的实例代码
  20. STM32电子钟万年历Proteus仿真_LCD1602显示

热门文章

  1. 八年级英语下册计算机教学总结,初中信息技术教学工作总结
  2. PPPoE获取到32位掩码的研究
  3. Java-购物车实践与应用
  4. C1认证学习五(HTTP)
  5. 无限天空服务器,滚动的天空无限钻石无限金币版
  6. 游戏界的“扛把子”,“3D 游戏之父”, 约翰•卡马克的传奇人生
  7. Linux MMC原理及框架详解
  8. android 三星调用拍照功能吗,玩转Galaxy S3拍照功能全解析
  9. 霹雳吧啦wz学习笔记1_卷积神经网络
  10. Go语言经典库使用分析(五)| Negroni 中间件(一)