jQuery ? NO, Axios——请求数据
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——请求数据相关推荐
- Cli4.5.x 中使用axios请求数据
Cli4.5.x 中使用axios请求数据 文章目录 Cli4.5.x 中使用axios请求数据 前言 一.安装并配置axios 1.安装axios 2.vue-axios 二.各种请求方法 三.请求 ...
- Vue之单文件组件的数据传递,axios请求数据及路由router
1.传递数据 例如,我们希望把父组件的数据传递给子组件. 可以通过props属性来进行传递. 传递数据三个步骤: 步骤1:在父组件中,调用子组件的组名处,使用属性值的方式往下传递数据 <Menu ...
- ajax type是get请求,jQuery的Ajax请求数据时type无法使用GET
写一个ASP.NET MVC例子,它是使用jQuery的$.Ajax来呼叫控制器的数据. 创建一个视图: 运行结果: 一切正常,但是本例子我们只是获取数据,并没有做任何数据POST上传至控制器,我们尝 ...
- vue中使用axios请求数据过程
使用axios请求数据过程 1. 导入axios包 import axios from 'axios' 2. 在钩子函数中调用函数 mounted() {this.getinitialdata() / ...
- 前端Vue学习之路(四)axios请求数据
axios 1.增加新知识 2.旧方案 3.新方案(一) 4.为什么要用拦截器 (新方案二) 1.增加新知识 假如每个组件都引用axios,后期如果axios库不再维护了,那每个组件都要改动 所以封装 ...
- Vue3 配置代理和使用全局axios请求数据
更详细请参考: https://blog.csdn.net/qq_28550263/article/details/120633610 vue3中配置全局代理和使用axios向服务器请求数据 main ...
- 今天试着用原生axios以及jquery下的axios请求数据
axios.get("https://route.showapi.com/9-2", {params: {area: "北京",showapi_appid: & ...
- 偏前端 - vue-cli(axios请求数据==》token+按接口参数顺序(参数值拼接base64)- MD5)...
token+按接口参数顺序(参数值拼接base64)-> MD5) 请教于"喵咪",再此特别鸣谢!~ 特别强调:import qs from qs; 这个内部方法一定要用哦. ...
- axios请求数据和拦截
mounted () { #//注册 this.axios.post(' http://localhost:3000/register',{ username:'laoch ...
最新文章
- Codeforces 895C - Square Subsets
- 研究人员探索gaze fixation对基于运动想象的脑机接口性能的影响
- dd命令测试linux磁盘io情况,【LINUX】正确的使用dd进行磁盘读写速度测试
- AS3.0第一个实例:(Hello World)
- HTML 元素内部添加预加载
- 计算机分数的简便运算,分数的简便运算和分数的解方程
- handler机制的原理_Handler机制竟然可以这样解释,我惊呆了!
- 【完结】深度学习CV算法工程师从入门到初级面试有多远,大概是25篇文章的距离...
- QML 可以多选ComboBox的实现
- element-ui的input加单位符号
- 代码-JS之淡入淡出背景自动切换
- 使用HTML5里的classList操作CSS类
- java编程用什么文本编辑器_编程必备,程序员应该都知道的7款文本编辑器
- iOS 手势识别(点按、长按、轻扫)
- 汽车故障诊断技术【3】
- 求助文,缺少stubs-n32_hard.h
- 【开发管理类软件必备知识视频教程之一】登录窗体前台注意事项
- 新闻分析:微软到底需要雅虎什么?
- java 判断图片格式_Java判断上传图片格式的实例代码
- STM32电子钟万年历Proteus仿真_LCD1602显示
热门文章
- 八年级英语下册计算机教学总结,初中信息技术教学工作总结
- PPPoE获取到32位掩码的研究
- Java-购物车实践与应用
- C1认证学习五(HTTP)
- 无限天空服务器,滚动的天空无限钻石无限金币版
- 游戏界的“扛把子”,“3D 游戏之父”, 约翰•卡马克的传奇人生
- Linux MMC原理及框架详解
- android 三星调用拍照功能吗,玩转Galaxy S3拍照功能全解析
- 霹雳吧啦wz学习笔记1_卷积神经网络
- Go语言经典库使用分析(五)| Negroni 中间件(一)