AJAX请求----javaweb

1、什么是 AJAX 请求

AJAX 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML) , 是指一种创建交互式网页应用的网页开发
技术。

  • ajax 是一种浏览器通过 js 异步发起请求, 局部更新页面的技术。
  • Ajax 请求的局部更新, 浏览器地址栏不会发生变化
  • 局部更新不会舍弃原来页面的内容

2、原生 AJAX 请求的示例

总的原生实例

<!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">
// 在这里使用 javaScript 语言发起 Ajax 请求, 访问服务器 AjaxServlet 中 javaScriptAjax
function ajaxRequest() {
// 1、 我们首先要创建 XMLHttpRequest
var xmlhttprequest = new XMLHttpRequest();
// 2、 调用 open 方法设置请求参数(true表示异步)
xmlhttprequest.open("GET","http://localhost:8080/16_json_ajax_i18n/ajaxServlet?action=javaScriptAj
ax",true)
// 4、 在 send 方法前绑定 onreadystatechange 事件, 处理请求完成后的操作。
xmlhttprequest.onreadystatechange = function(){
if (xmlhttprequest.readyState == 4 && xmlhttprequest.status == 200) {
var jsonObj = JSON.parse(xmlhttprequest.responseText);
// 把响应的数据显示在页面上
document.getElementById("div01").innerHTML = "编号: " + jsonObj.id + " , 姓名: " +
jsonObj.name;
}
}


// 3、 调用 send 方法发送请求
xmlhttprequest.send();
}
</script>
</head>
<body>
<button onclick="ajaxRequest()">ajax request</button>
<div id="div01">
</div>
</body>
</html>

在这里插入图片描述

3、jQuery 中的 AJAX 请求

$.ajax 方法

  • url 表示请求的地址
  • type 表示请求的类型 GET 或 POST 请求
  • data 表示发送给服务器的数据

格式有两种:

  • 一: name=value&name=value
  • 二: {key:value}

success 请求成功, 响应的回调函数
dataType 响应的数据类型
常用的数据类型有:

  • text 表示纯文本
  • xml 表示 xml 数据
  • json 表示 json 对象

data:

  1. 类型:String
  2. 发送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData
    选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如
    {foo:[“bar1”, “bar2”]} 转换为 ‘&foo=bar1&foo=bar2’。

dataType

  • 类型:String

  • 预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME
    类型就被识别为 XML。在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script
    则会执行这个脚本。随后服务器端返回的数据会根据这个值解析后,传递给回调函数。可用值:

  • “xml”: 返回 XML 文档,可用 jQuery 处理。

  • “html”: 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。

  • “script”: 返回纯文本 JavaScript 代码。不会自动缓存结果。除非设置了

  • “cache” 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的
    script标签来加载)

  • “json”: 返回 JSON 数据 。

  • “jsonp”: JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?

  • callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。 “text”: 返回纯文本字符串

success

  1. 类型:Function
  2. 请求成功后的回调函数。
  3. 参数:由服务器返回,并根据 dataType 参数进行处理后的数据;描述状态的字符串。
$("#ajaxBtn").click(function(){
$.ajax({
url:"http://localhost:8080/16_json_ajax_i18n/ajaxServlet",
// data:"action=jQueryAjax",
data:{action:"jQueryAjax"},
type:"GET",
success:function (data) {
// alert("服务器返回的数据是: " + data);
// var jsonObj = JSON.parse(data);
$("#msg").html("编号: " + data.id + " , 姓名: " + data.name);
},
dataType : "json"
});
});

. g e t 方 法 和 .get 方法和 .get.post 方法

  • url 请求的 url 地址
  • data 发送的数据
  • callback 成功的回调函数
  • type 返回的数据类型
// ajax--get 请求
$("#getBtn").click(function(){
$.get("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryGet",function (data) {
$("#msg").html(" get 编号: " + data.id + " , 姓名: " + data.name);
},"json");
});
// ajax--post 请求
$("#postBtn").click(function(){
$.post("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryPost",function (data)
{
$("#msg").html(" post 编号: " + data.id + " , 姓名: " + data.name);
},"json");
});

$.getJSON 方法

  • url 请求的 url 地址
  • data 发送给服务器的数据
  • callback 成功的回调函数
// ajax--getJson 请求
$("#getJSONBtn").click(function(){
$.getJSON("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQueryGetJSON",function
(data) {
$("#msg").html(" getJSON 编号: " + data.id + " , 姓名: " + data.name);
});
});

表单序列化 serialize()
serialize()可以把表单中所有表单项的内容都获取到, 并以 name=value&name=value 的形式进行拼接

// ajax 请求
$("#submit").click(function(){
// 把参数序列化
$.getJSON("http://localhost:8080/16_json_ajax_i18n/ajaxServlet","action=jQuerySerialize&" +
$("#form01").serialize(),function (data) {
$("#msg").html(" Serialize 编号: " + data.id + " , 姓名: " + data.name);
});
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值