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官方发布最新 ...
随机推荐
- LeetCode 24 Swap Nodes in Pairs (交换相邻节点)
题目链接: https://leetcode.com/problems/swap-nodes-in-pairs/?tab=Description Problem: 交换相邻的两个节点 如上 ...
- if中的-n -z linux_Shell
==========1 混淆的-n -z================= -n 表示这个变量或者字符串是否不为空.-z 表示这个变量或者字符串为空 上面这两句话中最重要的点是不通的 -n 关注的是 ...
- jenkins部署war包到远程服务器的tomcat
一.目的 jenkins上将war包,部署到远程服务器的tomcat上. 这边tomcat在windows 主机A上,版本apache-tomcat-8.5.23. jenkins在主机B上,cent ...
- Unity3D动作资源(AnimatinClip)优化
能做到去掉Scale曲线,降低浮点精度 using System; using UnityEngine; using System.Collections; using System.Collecti ...
- 【读书笔记】socket描述符选项[SOL_SOCKET]
#include <sys/socket.h> int setsockopt( int socket, int level, int option_name, ...
- 盘古分词修改支持mono和lucene.net3.03
盘古分词平台兼容性 在使用Lucece.net,需要一个中文的分词组件,比较好的是盘古分词,但是我希望能够在mono的环境下运行,就使用moma检查了一下盘古分词 Assembly Version M ...
- 仿QQ、微信翻页查看聊天记录
主界面MainActivity.class public class MainActivity extends Activity implements OnScrollListener{ privat ...
- gnuplot生成gif动画
最近有个任务需要生成一个动态变化的图,然后突然发现gnuplot竟然可以生成gif动画,当真是应正了博客Gnuplot surprising的子标题: I always tell myself: &q ...
- 静态类(static)与java值传递、引用传递小测
java中都是值传递.直接上代码了: class TestStaticA { static { System.out.println("b"); } public TestStat ...
- linux 命令行常用快捷键
linux命令行常用快捷键,区别于vim编辑器快捷键.熟练掌握下面的快捷键可提高操作linux的工作效率.当然最重要的是可以装屌. 1.移动光标快捷键Ctrl+a光标回到命令行首* Ctrl+e光标回 ...