Ajax登录效果源码

这篇博客分享了如何使用Ajax技术实现用户登录时的交互效果,包括无刷新验证和信息反馈。

用户登录信息

用户名:

密    码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
	String path = request.getContextPath();
	String basePath = request.getScheme() + "://"
			+ request.getServerName() + ":" + request.getServerPort()
			+ path + "/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>用户登录</title>
<script type="text/javascript" src="jq/jquery-1.8.3.js"></script>

<script type="text/javascript">
<!-- 第一种方法,比较简洁 --!>	
$(function() {
		//失去焦点事件
		$("#userId").blur(function() {
	
			$.get("AdminServlet", {
				name : $(this).val()
			}, function(msg) {
				if(msg=="1") {
					$("#s").html("用户名正确").css("color", "green");
				} else {
					$("#s").html("用户名不正确").css("color", "red");
				}

			})
		})
	})

	
<!-- 第二种方法,即Ajax的源码 --!>
	var xhr;
	//1. 创建XMLHttpRequest对象的函数
	function getXMLHttpRequest() {
		if (window.XMLHttpRequest) {
			return new XMLHttpRequest();
		}
	}
	//2. 文本框失去焦点事件
	function userValidate(name) {
		//获取 XMLHttpRequest
		xhr = getXMLHttpRequest();
		var userName = name.value;
		//初始化
		xhr.open("POST", "AccountSer?name=" + userName, true);
		//设置回调函数 
		xhr.onreadystatechange = resultData;
		xhr.send("");
	}

	//3. 回调函数
	function resultData() {
		var span = document.getElementById("s");
		if (xhr.readyState == 4) { //服务返回状态
			if (xhr.status == 200) { //服务端正确返回
				//接收返回的数据
				if (xhr.responseText == "1") {
					span.style.color = "green";
					span.innerHTML = "用户名正确";
				} else {
					span.style.color = "red";
					span.innerHTML = "用户名错误";
				}
			}
		}
	}
	
</script>
</head>

<body>
	<h2>用户登录信息</h2>
	<form>
		<p>
		
			用户名:<input type="text" name="user" id="userId" >
			<span id="s"></span>
		</p>
		<p>
			密   码:<input type="password" name="userPwd">
		</p>
		<p>
			<input type="submit" value="登 录" />
		</p>
	</form>
</body>
</html>


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值