ajax课1 源码
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script src="./js/my.js"></script>
<script src="./js/jquery-1.11.1.js"></script>
<script type="text/javascript">
function showCity(proV){
//根据选择的省份去后台查询对应的城市
var xhr=getXhr();
xhr.onreadystatechange=function(){
if(xhr.readyState==4){
//nj:南京;yz:扬州
var text=xhr.responseText;
var arr=text.split(";");
//["nj:南京","yz:扬州"]
//清空上一次城市选项
$("#city").html("");
for(var i=0;i<arr.length;i++){
var value=arr[i].split(":")[0];
var htmlText=arr[i].split(":")[1];
//新疆option
var option=new Option(htmlText,value);
$("#city").append(option);
}
}
}
xhr.open('get','city.do?proV='+proV,true);
xhr.send(null); } </script>
</head>
<body>
<select id="pro" onchange="showCity(this.value)">
<option value="1">请选择</option>
<option value="js">江苏</option>
<option value="ah">安徽</option>
</select>
<select id="city"></select>
</body>
</html>
package web; 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 ActionServlet extends HttpServlet { public void service(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("utf-8");
//获取请求资源路径
String uri=request.getRequestURI();
//截取 /list
String action=uri.substring(uri.lastIndexOf("/"),uri.lastIndexOf("."));
//设置返回的类型
response.setContentType("text/html;charset=utf-8");
//获取输出流
PrintWriter out=response.getWriter();
if("/checkUname".equals(action)){
/* //模拟服务器正在处理中。。。
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}*/
/*模拟服务器异常
* if(true){
throw new ServletException("有错啦---");
}*/
//接受用户传入的用户名,判断用户名是否一致
String name=request.getParameter("uname");
System.out.println(name);
//假设zs已经被占用
if("zs".equals(name)){
out.print("用户名被占用");
}else{
out.print("用户名可以用");
}
}else if("/city".equals(action)){
//获取页面传过来的省份
String proV=request.getParameter("proV");
if("1".equals(proV)){
out.print("-1,请选择省份");
}else if("js".equals(proV)){
//返回江苏的城市
out.print("nj:南京;yz:扬州");
}else if("ah".equals(proV)){
//返回安徽对应的城市
out.print("hf:合肥;wh:芜湖");
}
}
out.close();
} }
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script src="./js/my.js"></script>
<script src="./js/jquery-1.11.1.js"></script>
<script >
var uflag=false;//默认用户名验证不合法
var pflag=false;//默认密码验证不合法
function check_uname_get(){
//获取ajax对象
var xhr=getXhr();
//注册监听
xhr.onreadystatechange=function (){
//根据服务器返回的数据给页面做处理
if(xhr.readyState==4){
if(xhr.status==200){//服务器正常返回
var text=xhr.responseText;
//将text的内容显示在页面上
$("#name_msg").html(text);
}else{//服务器返回有异常
$("#name_msg").html("服务器异常,请稍后重试。。。")
} }else{//服务器没有返回
$("#name_msg").html("验证中,请稍后。。。")
}
}
//初始化
var url="checkUname.do?uname="+$("[name=uname]").val()+"&"+new Date().getTime();
xhr.open('get',encodeURI(url),true);
//真正发送请求
xhr.send(null);
} function check_uname_post(){
//获取ajax对象
var xhr=getXhr();
//注册监听
xhr.onreadystatechange=function (){
//根据服务器返回的数据给页面做处理
if(xhr.readyState==4){
//服务器返回的结果显示在页面中
if(xhr.status==200){//服务器正常返回
var text=xhr.responseText;
//将text的内容显示在页面上
$("#name_msg").html(text);
//如果服务器返回的内容为"用户名可用"
//用户名验证结果为true
if("用户名可用"==text){
uflag=true;
}else{
uflag=false;
}
}else{//服务器返回有异常
$("#name_msg").html("服务器异常,请稍后重试。。。")
} }else{
//服务器没有返回
$("#name_msg").html("验证中,请稍后。。。")
}
}
//初始化
var url="checkUname.do";
xhr.open('post',url,true);
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
//真正发送请求
xhr.send("uname="+$("[name=uname]").val()); } function check_pwd(v){
//密码必须为6位的数字
var reg=/^[0-9]{6}$/;
pflag=reg.text(v); } //验证整个表单(必须用户名可用且密码合法)
function checkForm(){
return iflag&&pflag;
}
</script>
</head>
<body>
<form action="registe.do" method="post" onsubmit="return checkForm()">
用户名:<input name="uname" onblur="check_uname_get()"/>
<span id="name_msg" style="color:red"></span><br/>
密码:<input type="password" name="pwd" onblur="check_pwd(this.value)"/>
<span id="pwd_msg" style="color:red"></span><br/><br/>
<input type="submit" value="注册"/> </form>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>使用ajax对象发送请求</title>
<script type="text/javascript" src="./js/my.js"></script> <script type="text/javascript">
//1.获取ajax对象
var xhr=getXhr();
//2.设置监听器
xhr.onreadystatechange=function(){
//5.处理服务器返回的数据
//响应结束时获取服务器返回的数据
if(xhr.readyState==4){
var text=xhr.responseText;
alert(text);
}
};
//3.初始化
xhr.open('get','checkUname.do',true);
//4.真正发送 get方法传的就是null
xhr.send(null); </script>
</head>
<body> </body>
</html>
function getXhr(){
var xhr=null;
if(window.XMLHttpRequest){//浏览器是否有ajax对象
xhr=new XMLHttpRequest();
}else{//低版本ie
xhr=new ActiveXObject("Microsoft.XMLHttp");
}
return xhr;
}
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
function getXhr(){
var xhr=null;
if(window.XMLHttpRequest){//浏览器是否有ajax对象
xhr=new XMLHttpRequest();
}else{//低版本ie
xhr=new ActiveXObject("Microsoft.XMLHttp");
}
alert(xhr);
} </script>
</head>
<body>
<a onclick="getXhr()">获取ajax对象</a>
</body>
</html>
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<servlet>
<servlet-name>ActionServlet</servlet-name>
<servlet-class>web.ActionServlet</servlet-class>
</servlet> <servlet-mapping>
<servlet-name>ActionServlet</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
ajax课1 源码的更多相关文章
- PHP+ajax聊天室源码!支持长轮循跟定时请求两种
var lastID = "1";//声明上次取回的消息的ID var isposted = false; var mGetTime;//设置setTimeout的返回值 // ...
- jQuery源码分析系列
声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://git ...
- jquery2源码分析系列
学习jquery的源码对于提高前端的能力很有帮助,下面的系列是我在网上看到的对jquery2的源码的分析.等有时间了好好研究下.我们知道jquery2开始就不支持IE6-8了,从jquery2的源码中 ...
- Catalyst揭秘 Day2 Catalyst源码初探
Catalyst揭秘 Day2 Catalyst源码初探 这节课从源码角度来讲catalyst. 首先有一个观点要澄清,就是技术不是越底层就越是性能和效率更高.因为除了指令执行性能以外,更重要的是架构 ...
- 16Aspx.com源码2013年10月到2013年12月详细
创建时间FROM: 创建时间TO: ExtJS合同管理信息系统源码 2013-12-13 [VS2008] 源码介绍: ExtJS合同管理信息系统源码浏览器兼容:IE,Firefox,谷歌等主 ...
- [转]jQuery源码分析系列
文章转自:jQuery源码分析系列-Aaron 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://github.com/JsAaro ...
- zepto源码分析系列
如果你也开发移动端web,如果你也用zepto,应该值得你看看.有问题请留言. Zepto源码分析-架构 Zepto源码分析-zepto(DOM)模块 Zepto源码分析-callbacks模块 Ze ...
- jQuery源码分析系列(转载来源Aaron.)
声明:非本文原创文章,转载来源原文链接Aaron. 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://github.com/JsAa ...
- jQuery源码分析系列——来自Aaron
jQuery源码分析系列——来自Aaron 转载地址:http://www.cnblogs.com/aaronjs/p/3279314.html 版本截止到2013.8.24 jQuery官方发布最新 ...
随机推荐
- HTTP协议剖析 (附HttpWatch工具监控网络请求)
工具:HttpWatch Prov7.2.13破解版(带正版key) HTTP协议概述 思考2个要点: 第一:浏览器和服务器是通过什么连接的 第二:这种连接方式是怎么实现的 通过Interne ...
- jfinal如何设置使用哪种模板引擎(视图)
1.jfinal\com\jfinal\core\Controller.java /** * Render with view use default type Render configured i ...
- mysql if判断
select if(SUBSTR('06622200556',1,2)='06',0,1) from t_member_product_adb limit 2 输出结果为:0,0
- 如何通过python代码解压zip包
转载至https://www.cnblogs.com/flyhigh1860/p/3884842.html 很多人在Google上不停的找合适自己的压缩,殊不知Py的压缩很不错.可以试试.当然C#,J ...
- Qt qDebug() 的使用方法
在Qt程序调试的时候,经常需要打印一些变量,那么我们就需要使用qDebug()函数,这种函数有两种使用方法,如下所示: QString s = "Jack"; qDebug() & ...
- zTree实现节点修改的实时刷新
一.应用场景 在实际应用中会遇到动态操作树各节点的需求,在增加树节点后如何实时动态刷新树就十分有必要了. 二.项目实践 比如要在test1234节点下新建子节点,首先要选中test1234节点,添 ...
- php中调用这个功能可以在web页面中显示hello world这个经典单词
php程序写的时间长了,自然对他所提供的功能了如指掌,他所提供的一大堆功能,真是觉得很好用,但有时候会发现php也缺少一些功能,自己总是会产生为php添加一些自定义的功能的想法.久而久之,终于今天憋不 ...
- MapReduce的洗牌(Shuffle)
Shuffle过程:数据从map端传输到reduce端的过程~ Map端 每个map有一个环形内存缓冲区,用于存储任务的输出.默认大小100MB(io.sort.mb属性),一旦达到阀值0.8(io. ...
- 如何使ul中li元素横向排列且不换行
外层div容器宽度固定,ul宽度随li(li宽度固定)的增加而撑开,但是当ul中li的宽度之和大于div时,ul没有撑开,而是li换行了,如何使li不换行? 解决方法:主要是外面容器设置为white- ...
- HDU 2819 - Swap - [二分图建模+最大匹配]
题目链接:https://cn.vjudge.net/problem/HDU-2819 Given an N*N matrix with each entry equal to 0 or 1. You ...