Java基础96 ajax技术的使用
本文知识点(目录):
1、ajax的概念
2、使用ajax技术获取服务端的数据_实例
3、使用ajax技术检查用户名是否已存在_实例
4、使用ajax技术验证登录页面的用户名和密码_实例
1、ajax的概念
ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。
ajax的全称是Asynchronous JavaScript and XML,即异步JavaScript+XML。它并不是新的编程语言。
1.2、XMLHttpRequest 对象
var xhr;
if(window.XMLHttpRequest){
xhr = new XMLHttpRequest(); //IE7+,Firefox,Chrome,Opera,Safari...
}else{
xhr = new ActiveXObject("Microsoft.XMLHTTP"); //IE6,IE5...
}
1.3、XMLHttpRequest 发送请求
request.open("GET","get.php",true); //方式1
request.send(); request.open("POST","post.php",true); //方式2
request.send(); request.open("POST","create.php",true); //方式3
request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
request.send("name=jack&sex=male");
1.4、ajax的优点和缺点
优点:在不更新整个页面的前提下维护数据,web应用程序更为迅捷的回应用户动作。
缺点:
1.破坏了浏览器的后退功能。
解决方案:HTML5创建或使用一个隐藏的iframe来重现页面上的变更。
2.破坏加入收藏书签功能。
解决方案:
1.HTML5用URL片段标识符来保持追踪,允许用户回到指定的某个应用程序状态。
2.直接操作浏览历史,以字符串的形式存储网页状态,将网页加入网页书签、收藏夹时状态会被隐形保留。
除此之外,ajax还需要注意的一点是:网络延迟,即用户发出请求到服务器回应之间的间隔。
处理方式是用可视化组件告诉用户系统正在进行的后台操作和正在读取数据和内容。
2、使用ajax技术获取服务端的数据_实例
获取服务器test.txt中的信息
ajax.html 页面(ajax)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ajax.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> </head> <body>
<input type="button" value="获取服务端数据" onclick="getData()">
</body>
<script>
//XMLHttpRequest:是js中唯一能够跟后台进行交互的对象
var xhr;
function getData(){
//1.判断浏览器,根据浏览器对xmlhttpRequest的支持创建对象
if(window.XMLHttpRequest){
xhr=new XMLHttpRequest();
}else{
//IE5 IE6
xhr=new ActiveXObject('Microsoft.XMLHTTP');
}
//2.打开一个链接(提交方式,请求资源,是否异步请求)
xhr.open('get','test.txt',true);
//3.当请求状态发生变化时触发回调函数
xhr.onreadystatechange=callback;//callback:回调函数
//4.发送请求
xhr.send();
} function callback(){//回调函数
//判断请求状态是否完成
if(xhr.readyState==4){
//判断响应是否成功
if(xhr.status==200){
//获取服务端响应的数据
var msg=xhr.responseText;
alert(msg);
}
}
}
</script>
</html>
结果图
3、使用ajax技术检查用户名是否已存在_实例
frame.js 文件
function $(id){
return document.getElementById(id);
} function elesByName(name){
return document.getElementsByName(name);
} function elesByTag(name){
return document.getElementsByTagName(name);
} function createEle(name){
return document.createElement(name);
} //封装trim函数(去除空格)
String.prototype.trim=function(){
return this.replace(/(^\s*)|(\s*$)/g,"");
};
CheckUnameServlet 类
package com.shore.a_servlets; import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class CheckUnameServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//假设数据库包含如下用户
String[] names = {"admin","softeem","users1","rose","jack"};
//获取要检查的用户名
String name = request.getParameter("uname");
System.out.println("进入后台:"+name);
//假设该用户不存在
boolean flag = false;
for(String s:names){
if(s.equals(name)){
flag = true;
break;
}
}
PrintWriter out=response.getWriter();
if(flag){
//账号不可用(数据库中已存在)
out.println("no");
}else {
//可以注册
out.println("yes");
}
out.flush();//刷新
out.close();//关闭资源
}
}
index.html 页面(ajax)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>index.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
<script type="text/javascript" src="js/frame.js"></script>
</head>
<body>
用户名:<input type="text" id="uname"/>
<input type="button" value="检查用户名" onclick="check()">
<span id="msg"></span>
</body>
<script>
var xhr;
//1.判断浏览器
function getXhr(){
if(window.XMLHttpRequest){
xhr=new XMLHttpRequest();
}else{
xhr=new ActiveXObject("Microsoft.XMLHTTP");
}
}
function check(){
getXhr();
//获取用户名
var name=$('uname').value;
//2.打开一个链接
xhr.open('get','CheckUnameServlet?uname='+name,true);
//3.当请求状态发生改变时触发回调函数
xhr.onreadystatechange=callback;
//4.发送
xhr.send();
} function callback(){
//判断请求是否完成
if(xhr.readyState==4){
//判断响应是否完成
if(xhr.status==200){
//获取服务端相应数据
var data=xhr.responseText;
if(data.trim()=="yes"){
$('msg').innerHTML="<font color='green'>账号可用!</font>";
}else{
$('msg').innerHTML="<font color='red'>账号已被注册!</font>";
}
}
}
}
</script>
</html>
结果图
4、使用ajax技术验证登录页面的用户名和密码_实例
ServiceModel 实体类
package com.shore.util; public class ServiceModel {
private int code; //状态码
private String msg;//提示信息 public ServiceModel() {
}
public ServiceModel(int code, String msg) {
super();
this.code = code;
this.msg = msg;
}
public int getCode() {
return code;
}
public void setCode(int code) {
this.code = code;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg = msg;
}
}
LoginServlet 类
package com.shore.a_servlets; import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.shore.util.ServiceModel; public class LoginServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
String uname=request.getParameter("uname");
String upass=request.getParameter("upass"); System.out.println(uname+"---"+upass);
PrintWriter out=response.getWriter();
//创建业务模型对象
ServiceModel model=new ServiceModel();
if("admin".equals(uname)){
if("123456".equals(upass)){
model.setCode(1);
model.setMsg("登录成功");
}else{
model.setCode(0);
model.setMsg("密码错误");
}
}else{
model.setCode(-1);
model.setMsg("账号不存在");
}
//json数据格式
String msg="{'code':'"+model.getCode()+"','msg':'"+model.getMsg()+"'}";
out.println(msg);//传到页面去
out.flush();
out.close();
}
}
ajax_post.html 页面(ajax)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ajax_post.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">-->
<script type="text/javascript" src="js/frame.js"></script>
</head> <body>
<div>
<table id="login_form">
<caption>用户登陆</caption>
<tr>
<th colspan="2"><span id="msg"></span></th>
</tr>
<tr>
<td>用户名:</td>
<td><input type="text" id="uname"></td>
</tr>
<tr>
<td>密码:</td>
<td><input type="password" id="upass"></td>
</tr>
<tr>
<td>
<input type="button" value="登陆" onclick="login()"/>
</td>
</tr>
</table>
<span id="ok"></span>
</div></body>
<script>
var xhr;
function login(){
var name = $("uname").value;
var pass = $("upass").value;
//拼接需要提交的数据 "uname=admin&upass=123456"
var query = "uname="+name+"&upass="+pass;
//对需要提交的数据进行转码(防止乱码)
query=encodeURI(query);
//1.判断浏览器
if(window.XMLHttpRequest){
xhr = new XMLHttpRequest();
}else{
xhr = new ActiveXObject("Microsoft.XMLHTTP");
}
//2.打开连接
xhr.open('post','LoginServlet',true);
//3.当请求状态发生改变时触发回调函数
xhr.onreadystatechange=handlerData;
//设置请求头信息(对于post)
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
//4.发送请求(参数为需要提交的数据)
xhr.send(query);
}
function handlerData(){
if(xhr.readyState == 4 && xhr.status == 200){
var data = xhr.responseText;
data = data.trim();
//alert(data);//弹出框
//把json字符串转为javascript对象
data=eval("("+data+")");
if(data.code==1){
$("login_form").style.display="none";
$("ok").innerHTML="<font color='green'>"+data.msg+"</font>";
}else if(data.code==0){
$("msg").innerHTML="<font color='red'>"+data.msg+"</font>";
}else{
$("msg").innerHTML="<font color='red'>"+data.msg+"</font>";
}
}
}
</script>
</html>
结果图
Java基础101 Struts2下的 jquery+ajax+struts 技术实现异步刷新功能
ajax技术 更详细的内容:https://www.cnblogs.com/dulmcat/p/5812062.html
原创作者:DSHORE 作者主页:http://www.cnblogs.com/dshore123/ 原文出自:https://www.cnblogs.com/dshore123/p/10708447.html 欢迎转载,转载务必说明出处。(如果本文对您有帮助,可以点击一下右下角的 推荐,或评论,谢谢!) |
Java基础96 ajax技术的使用的更多相关文章
- Java基础-零拷贝技术应用案例
Java基础-零拷贝技术应用案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 零拷贝技术在Hadoop生态圈中很多组件得到应用,典型的比如kafka组件,它就很成功的应用了零拷贝 ...
- Java基础之IO技术(一)
---恢复内容开始--- Java基础中的IO技术可谓是非常重要,俗话说的好,万丈高楼起于垒土之间.所以学习Java一定要把基础学好,今天我们来学习IO技术的基础. IO无非就是输入与输出,而其中处理 ...
- java基础75 xpth技术(网页知识)
1.xpth技术 1.1.xpath的作用 主要用于快速获取所需的节点对象. list<Node> selectNodes("xpath"); 查询多个节点对象 ...
- java 基础之 反射技术
1. java代码 在 java 语言中最核心的就是代码的运行, 按照面向对象的思想,在调用java代码时往往需要先创建对象,再调用方法, 而写在方法中的即所谓的java 代码 一段java代码在程序 ...
- JAVA基础之会话技术-Cookie及Session
至此,学习Servlet三个域对象:ServletContext(web项目).request(一次请求).Session(一个客户端)!均有相同的方法! 从用户开始打开浏览器进行操作,便开始了一次会 ...
- 阿里P7整理“硬核”面试文档:Java基础+数据库+算法+框架技术等
现在的程序员越来越多,大部分的程序员都想着自己能够进入大厂工作,但每个人的能力都是有差距的,所以并不是人人都能跨进BATJ.即使如此,但身在职场的我们一刻也不能懈怠,既然对BATJ好奇,那么就要朝这个 ...
- 跟阿根一起学Java Web开发二:使用Ajax技术及XML与JSON实现输出
如今B/S结构的系统使用Ajax技术是再平常只是的了.今天我们就来探讨下在JSPGenSDF第四版中:怎样使用Ajax技术.怎样输出XML文件及JSON格式数据输出. 怎样搭建一个最基础的JSPGen ...
- Java之Ajax技术
ajax(asynchronouse javascript and xml) 异步的javascript 和 xml(现在常把xml换成json): ajax是2005年提出的,在2006,2007年 ...
- java基础篇---I/O技术
java基础篇---I/O技术 对于任何程序设计语言而言,输入输出(I/O)系统都是比较复杂的而且还是比较核心的.在java.io.包中提供了相关的API. java中流的概念划分 流的方向: 输 ...
随机推荐
- dedecms 5.7 采集目标文章的发布时间 采集后变成当前本地时间
我已经解决了.现在把方法告诉你.都是我自己摸索出来的..虽然我不知道什么意思...下面是步骤: 1:找到 co_export.php然后找到这段代码: else if($itemName == 'pu ...
- 【推荐】使用Ultrapico Expresso学习正则表达式
Ultrapico Expresso是我工作中经常使用的一个非常强大的正则表达式构建.测试以及代码生成工具.它能够对你构建的正则表达式进行解析.验证,并输出解析结果,提供性能测试工具,支持C#.VB等 ...
- Qt shortcuts
ESC 切换到代码编辑模式 F1 查看帮助 F4 .h 与 .c or .cpp之间切换 shift + F2 声明与定义间切换 Ctrl + tab 切换已打开的文件 Ctrl + B 编 ...
- ELK技术实战-安装Elk 5.x平台
ELK技术实战–了解Elk各组件 转载 http://www.ywnds.com/?p=9776 ELK技术实战-部署Elk 2.x平台 ELK Stack是软件集合Elasticsearch. ...
- ubuntu16.04.1下安装mysql
版本信息 ubuntu版本:16.04.1 mysql-server版本:5.7.23 安装 先查看一下apt可获取的mysql版本 ubuntu@VM-0-4-ubuntu:~$ apt searc ...
- 解决audio和video在手机端无法自动播放问题
各大浏览器都为了节省流量,做出了优化,在用户没有行为动作时(交互)不予许自动播放 <audio src="music/bg.mp3" autoplay loop contro ...
- 简易selenium自动化测试框架(Python)
最近空闲时间在探索Selenium的自动化测试,简单的写了一个小框架来测试公司的一个web产品.该框架包括以下模块: 1. Test case编写模式(page模式,参考之前的博文http://www ...
- Dojo框架:误解与现实[转载]
随着Ajax技术的流行,越来越多的Web应用使用Ajax技术来提高用户体验.使用Ajax技术的一个重要优势是不需要额外的浏览器插件支持,只需要使用浏览器原生的API,并利用JavaScript来操作即 ...
- Javaweb学习笔记——(五)——————DOM&XML目录
1.表单提交方式 *使用submit提交 <form> <input type="submit" /> </form> *使用button提交表 ...
- Linux 设置最大链接
最大连接数 ulimit -SHn # 最大文件句柄数,最大打开文件数(等同最大连接数) ulimit -a # 查看 /etc/security/limits.conf # 进程最大打开文件数 # ...