Ajax&Axios

Ajax

注:AJAX很少使用,现在都使用更简单的Axios所以只需要了解Ajax即可

概念

AJAX,全称"Asynchronous JavaScript and XML"(异步JavaScript和XML)

作用:

  • 与服务器进行数据交换,通过Ajax可以给服务器发送请求,并获取服务器响应的数据。
  • 异步交换:可以在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术。

入门

AJAX不是一种新的编程语言,而是一种使用现有标准的新方法。

首先以Servlet方式编写

  1. 编写AjaxServlet,并使用response输出字符串
java 复制代码
@Webservlet("/ajaxServlet" )
public class AjaxServlet extends Httpservlet {
	@override
	protected void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException{
		//响应数据
		response.getWriter().write("Hello Ajax");
	}
}
  1. 创建XMLHttpRequest对象:用于和服务器交换数据
js 复制代码
var xmlhttp;
if(window.XMLHttpRequest){
	xmlhttp = new XMLHttpRequest();
}else{
	xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
  1. 向服务器发送数据
js 复制代码
xmlhttp.open("GET","url");
xmlhttp.send();//发送请求
  1. 获取服务器响应数据
js 复制代码
xmlhttp.onreadystatechange = function(){
	if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
		alert(xmlhttp.responseText);
	}
}

Axios

前面的AJAX的代码很复杂,所以Axios对其进行了封装,简化了书写

使用方法

以向localhost:8080/test/ajaxTest这个地址发送username这个属性

  1. 引入axios的js文件
js 复制代码
<script src="js/axios-0.18.0.js"><script>
  1. 使用axios发送请求,并获取响应结果
js 复制代码
axios({
	method:"get",
	url:"http://localhost:8080/test/ajaxTest?username=zhangsan"
}).then(function(resp){
	alert(resp.data);
})
axios({
	method:"post",
	url:"http://localhost:8080/test/ajaxTest",
	data:"username=zhangsan"
}).then(function(resp){
	alert(resp.data);
});
  1. 为了方便axios为所有的请求方法起别名
js 复制代码
//发送get请求
axios.get("url")
	.then(function(resp){
		alert(resp.data);
});
//发送post请求
axios.post("url","参数")
	.then(function(resp){
	alert(resp.data);
});
相关推荐
yinuo2 小时前
前端跨页面通讯终极指南⑥:SharedWorker 用法全解析
前端
PineappleCoder6 小时前
还在重复下载资源?HTTP 缓存让二次访问 “零请求”,用户体验翻倍
前端·性能优化
拉不动的猪7 小时前
webpack编译中为什么不建议load替换ast中节点删除consolg.log
前端·javascript·webpack
李姆斯7 小时前
Agent时代下,ToB前端的UI和交互会往哪走?
前端·agent·交互设计
源码获取_wx:Fegn08957 小时前
基于springboot + vue健身房管理系统
java·开发语言·前端·vue.js·spring boot·后端·spring
闲谈共视7 小时前
基于去中心化社交与AI智能服务的Web钱包商业开发的可行性
前端·人工智能·去中心化·区块链
CreasyChan7 小时前
C# 反射详解
开发语言·前端·windows·unity·c#·游戏开发
JIngJaneIL8 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
hashiqimiya9 小时前
两个步骤,打包war,tomcat使用war包
java·服务器·前端
零度@10 小时前
Java中Map的多种用法
java·前端·python