Web阶段:第二十章:Ajax请求
2023-06-13 09:13:27 时间
什么是Ajax请求? AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。 ajax是一种浏览器异步发起请求。局部更新页面的技术。 1、异步发起请求 2、局部更新页面
原生Ajax请求的实现(了解)
<script type="text/javascript">
function ajaxRequest() {
// 1、我们首先要创建XMLHttpRequest
var xmlHttpRequest = new XMLHttpRequest();
// 2、调用open方法设置请求参数
xmlHttpRequest.open("GET", "http://localhost:8080/day17/ajaxServlet?action=javaScriptAjax", true);
// 4、在send方法前绑定onreadystatechange事件,处理请求完成后的操作。
xmlHttpRequest.onreadystatechange = function(){
if (xmlHttpRequest.readyState == 4 && xmlHttpRequest.status == 200) {
alert("响应回来啦");
// alert("服务器返回的数据是:" + xmlHttpRequest.responseText);
var jsonObj = JSON.parse( xmlHttpRequest.responseText );
// alert( "编号:" + jsonObj.id + ",姓名:" + jsonObj.name );
document.getElementById("div01").innerHTML = "编号:" + jsonObj.id + ",姓名:" + jsonObj.name;
}
}
// 3、调用send方法发送请求
xmlHttpRequest.send();
alert("这是请求后面的代码");
}
</script>
Jquery中的Ajax请求 $.ajax方法 url 请求的地址 type 请求的方式GET或POST data 请求的参数(发送给服务器的数据) 支持两种格式 一:name=value&name=value 二: { 属性名:值 }
success 请求成功后响应的函数 dataType 服务器回传的数据类型 1.text返回纯文本、 2.xml、 3.json返回json对象
案例:
// ajax请求
$("#ajaxBtn").click(function(){
$.ajax({
url:"http://localhost:8080/day17/ajaxServlet",
type:"GET",
data:"action=jqueryAjax",
success:function(msg){
// 这个success的函数。一定要有一个参数。这个参数是服务器回传的数据
alert(msg);
$("#msg").html("编号是:" + msg.id + ",姓名:" + msg.name);
},
dataType:"json"
});
});
.get方法和.post方法url 请求的地址data 请求的数据callback 请求成功的回调函数type 响应的数据类型案例:
// ajax--get请求
$("#getBtn").click(function(){
$.get("http://localhost:8080/day17/ajaxServlet",{
action:"jqueryGet"
},function(msg){
// msg 请求成功的回调函数。参数msg是用来接收响应的数据
$("#msg").html("编号是:" + msg.id + ",姓名:" + msg.name);
},"json");
});
// ajax--post请求
$("#postBtn").click(function(){
// post请求
$.post("http://localhost:8080/day17/ajaxServlet","action=jqueryPost",function(msg){
// msg 请求成功的回调函数。参数msg是用来接收响应的数据
$("#msg").html("post请求 编号是:" + msg.id + ",姓名:" + msg.name);
},"json");
});
$.getJSON方法 url 请求的地址 data 请求的参数 callback 成功的回调
getJSON 请求方式固定是GET请求,响应的数据,固定是json格式。 案例:
// ajax--getJson请求
$("#getJSONBtn").click(function(){
// 调用
$.getJSON("http://localhost:8080/day17/ajaxServlet","action=jqueryGetJSON",function(msg){
$("#msg").html("getJSON请求 编号是:" + msg.id + ",姓名:" + msg.name);
});
});
表单序列化serialize() serialize() 方法可以把一个form表单中所有的表单项。都以字符串name=value&name=value的形式进行拼接,省去我们很多不必要的工作。
由于.get、.post和getJSON这三个方法的底层都是直接或者间接地使用
// ajax请求
$("#submit").click(function(){
// 把参数序列化
// serialize() 方法可以把表单项以name=vlaue&name=value进行拼接。
var data = $("#form01").serialize();
alert(data);
//当我们点击这个按钮的时候,我们希望把表单中所有的表单项,
// 以name=value&name=value的信息,进行拼接,然后发送给服务器
$.getJSON("http://localhost:8080/day17/ajaxServlet","action=jquerySerialize&" + data,function(msg){
$("#msg").html("jquerySerialize 编号是:" + msg.id + ",姓名:" + msg.name);
});
});
实例:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="script/jquery-1.7.2.js"></script>
<script type="text/javascript">
$(function(){
// ajax请求
$("#ajaxBtn").click(function(){
$.ajax({
url : "ajaxServlet", // 请求地址
error:function(){ // 请求失败回调
alert("请求失败");
},
success:function(data){ // 请求成功回调
alert( data );
},
type:"POST", // 请求的方式
dataType:"json", // 返回的数据类型为json对象
data:{ // 请求的参数
action:"jqueryAjax",
a:12,
date: new Date()
}
});
});
// ajax--get请求
$("#getBtn").click(function(){
$.get(
"ajaxServlet",{
action:"jqueryGet",
a:12,
date:new Date()
},function(data){alert(data);},"json"
);
});
// ajax--post请求
$("#postBtn").click(function(){
// post请求
$.post(
"ajaxServlet", // 请求路径
{ // 请求参数
action:"jqueryPost",
a:12,
date:new Date()
},
function(data){ alert( data ) }, // 成功的回调函数
"text" // 返回的数据类型
);
});
// ajax--getJson请求
$("#getJsonBtn").click(function(){
// 调用
$.getJSON(
"ajaxServlet", // 请求路径
{ // 请求参数
action:"jqueryGetJSON",
a:12,
date:new Date()
},
function(data){ alert( data ) } // 成功的回调函数
);
});
// ajax请求
$("#submit").click(function(){
// 把参数序列化
var data = $("#form01").serialize();
alert(data);
});
});
</script>
</head>
<body>
<div>
<button id="ajaxBtn">$.ajax请求</button>
<button id="getBtn">$.get请求</button>
<button id="postBtn">$.post请求</button>
<button id="getJsonBtn">$.getJSON请求</button>
</div>
<br/><br/>
<form id="form01" >
用户名:<input name="username" type="text" /><br/>
密码:<input name="password" type="password" /><br/>
下拉单选:<select name="single">
<option value="Single">Single</option>
<option value="Single2">Single2</option>
</select><br/>
下拉多选:
<select name="multiple" multiple="multiple">
<option selected="selected" value="Multiple">Multiple</option>
<option value="Multiple2">Multiple2</option>
<option selected="selected" value="Multiple3">Multiple3</option>
</select><br/>
复选:
<input type="checkbox" name="check" value="check1"/> check1
<input type="checkbox" name="check" value="check2" checked="checked"/> check2<br/>
单选:
<input type="radio" name="radio" value="radio1" checked="checked"/> radio1
<input type="radio" name="radio" value="radio2"/> radio2<br/>
<input id="submit" type="submit" />
</form>
</body>
</html>
2)AjaxServlet的代码如下:
package com.atguigu.servlet;
import java.io.IOException;
import java.util.Random;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.atguigu.gson.GsonTest;
import com.google.gson.Gson;
public class AjaxServlet extends BaseServlet {
private static final long serialVersionUID = 1L;
protected void javaScriptAjax(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("ajax请求过来了 a--" + request.getParameter("a"));
Random random = new Random(System.currentTimeMillis());
// 使用随机数,可以让客户端看到变化
response.getWriter().write(
new Gson().toJson(new GsonTest.Person(random.nextInt(100), "12312")));
}
protected void jqueryAjax(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("jqueryAjax请求过来了 a--" + request.getParameter("a"));
Random random = new Random(System.currentTimeMillis());
// 使用随机数,可以让客户端看到变化
response.getWriter().write(
new Gson().toJson(new GsonTest.Person(random.nextInt(100), "12312")));
}
protected void jqueryGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("jqueryGet请求过来了 a--" + request.getParameter("a"));
Random random = new Random(System.currentTimeMillis());
// 使用随机数,可以让客户端看到变化
response.getWriter().write(
new Gson().toJson(new GsonTest.Person(random.nextInt(100), "12312")));
}
protected void jqueryPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("jqueryPost请求过来了 a--" + request.getParameter("a"));
Random random = new Random(System.currentTimeMillis());
// 使用随机数,可以让客户端看到变化
response.getWriter().write(
new Gson().toJson(new GsonTest.Person(random.nextInt(100), "12312")));
}
protected void jqueryGetJSON(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println("jqueryGetJSON请求过来了 a--" + request.getParameter("a"));
Random random = new Random(System.currentTimeMillis());
// 使用随机数,可以让客户端看到变化
response.getWriter().write(
new Gson().toJson(new GsonTest.Person(random.nextInt(100), "12312")));
}
}
相关文章
- Ajax-hook拦截全局ajax请求操作
- SpringBoot2核心技术-web开发
- 什么是Ajax以及ajax请求的步骤[通俗易懂]
- 盘点十大主流go web框架
- SpringBoot Web开发精解
- 【纯干货】用了这么多年的 SpringBoot 你知道什么是 SpringBoot 的 Web 类型推断吗?
- 开源Web版Linux,数据库,Redis,MongoDB统一管理操作平台Go语言版本
- 新技术Web项目使用Redis实现高性能(web项目使用redis)
- Linux为Web服务器带来的福音(linux做web服务器)
- Nginx高性能Web服务器:Nginx HTTP负载均衡和反向代理的配置与优化(第六章)
- Nginx高性能Web服务器:Nginx与jsp、asp.net、perl的安装与配置(第五章)
- Ajax技术实现MySQL数据查询与更新(ajax连接mysql)
- Exploring the Power and Functionality of Oracle OC4J for Efficient Web Development(oracleoc4j)
- 器Linux下搭建简易Web服务器(linux下web服务)
- 基于Linux的Web服务器构建奇迹(linux web服务器)
- 基于C语言技术的Web应用程序开发与MySQL集成(c web mysql)
- php基于ApachMysqlphp的Web开发实现技术(apach mysql)
- Ajax注册MySQL极速轻量注册引擎(ajax注册mysql)
- Ajax实现对Oracle的异步操作(ajax操作oracle)
- Web构建Redis连接简单而有效的实现方式(web 连接redis)
- 从Web端查看Redis的实时状态(web查看redis)
- Web应用实战使用Redis最佳实践(web redis实战)
- 使用Redis加快部署Web应用的速度(redis部署web应用)
- Web代理(Asp版)
- vs.Net2003无法打开或创建Web应用程序若干解决办法.
- 比较简单实用的WEB安全设置总结