Ajax:

即"Asynchronous JavaScript And XML", 异步JavaScript和XML , 是指一种创建的交互式页面应用的网页开发技术,它并不是新的技术

ajax 并非一种新的技术,而是几种原有技术的结合体。由以下几种技术组合而成

  • 1.使用CSS和XHTML来表示
  • 2.使用DOM模型来交互和动态显示
  • 3.XMLHTTPRequest来和服务器进行异步通信,是ajax的基础
  • 4.使用JavaScript来绑定和调用

在以上所述技术中,除了XmlHttpRequest对象以外,其他所有的技术都是基于Web标准并且已经得到了广泛使用,XMLHTTPRequest虽然还没有被W3C采纳,但已经是一种事实的标准。

典例:

  • 注册网站时,提示输入的用户名已经被注册

作用:

如果想要刷新网页局部内容,那么需要重新载入整个网页。Ajax解决了局部刷新的问题,提高了用户体验。

1 Ajax的简单使用

创建对象:

function ajaxFunction(){
var xmlHttp;
try{ // Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
}
catch (e){
try{// Internet Explorer
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){}
}
} return xmlHttp;
}

发送请求:

     //执行get请求
function get(){
// 1 创建xmlhttprequest对象
var request = ajaxFunction()
// 2 发送请求 参数一 请求类型 参数二 路径 参数三 是否异步
request.open("GET","/8AjaxAndJquery/ServletDemo01",true);
request.send();
}

2 AJAX GET 向服务器发送数据,获取服务器响应的数据

/*     //向Servlet发送数据
function get(){
// 1 创建xmlhttprequest对象
var request = ajaxFunction()
// 2 发送请求 参数一 请求类型 参数二 路径 参数三 是否异步
request.open("GET","/8AjaxAndJquery/ServletDemo01?name=aa&age=18",true);
request.send();
} */ //接收Servlet响应的数据
function get(){
// 1 创建xmlhttprequest对象
var request = ajaxFunction()
// 2 发送请求 参数一 请求类型 参数二 路径 参数三 是否异步
request.open("GET","/8AjaxAndJquery/ServletDemo01?name=aa&age=18",true);
// 3 获取响应数据,注册监听的意思,如果状态改变,执行等号右边的方法
request.onreadystatechange = function(){
if(request.readyState == 4 && request.status == 200){
//弹出响应的信息
alert(request.responseText);
}
}
request.send();
}

3 AJAX POST 向服务器发送数据,获取服务器响应的数据

//1 创建对象
function ajaxFunction(){
var xmlHttp;
try{ // Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
}
catch (e){
try{// Internet Explorer
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){}
}
} return xmlHttp;
} //2 发送请求
function post(){
// 1 创建对象
var request = ajaxFunction();
// 2 发送请求
request.open("POST" ,"/8AjaxAndJquery/ServletDemo01" ,true);

// 如果要获取数据,加一个状态的监听
request.onreadystatechange = function(){
if(request.readyState == 4 && request.status == 200){
alert("post:"+request.responseText);
}
}
// 3 带数据过去
//如果是post请求,那么这里要添加请求头,说明提交的数据是一个经过url编码的form表单数据
request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
//在send方法里面写表单数据
request.send("name=aobama&age=29");
}

4 Ajax实现校验用户名功能

1 DAO层校验用户名,用ScalarHandler获取聚合函数count()的数量值,>0则用户名已经存在

@Override
/**
* 校验用户名是否存在
*/
public boolean checkUsername(String name) throws SQLException { QueryRunner runner = new QueryRunner(JDBCUtil02.getDataSource());
String sql = "select count(*) from test where name = ?";
Long result = (Long) runner.query(sql, new ScalarHandler() , name);
return result>0;
}

2 Servlet交互前后端数据

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
//检测是否存在
request.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=UTF-8");
String name = request.getParameter("name");
System.out.println("name:"+name);
UserDao dao = new UserDaoImpl();
boolean isExist = dao.checkUsername(name);
//通知页面
if(isExist){
response.getWriter().println(1);
}else{
response.getWriter().println(2);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

3 前端JSP&AJAX实现异步校验功能,绑定onblur函数,失去焦点执行

<script type="text/javascript">
//1 创建对象
function ajaxFunction(){
var xmlHttp;
try{ // Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
}
catch (e){
try{// Internet Explorer
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){}
}
} return xmlHttp;
} function checkUserName(){
//获取输入框的值
var name = document.getElementById("name").value;
// alert(name);
//1 创建对象
var request = ajaxFunction();
//2 发送请求
request.open("POST","/8AjaxAndJquery/CheckUserNameServlet", true);
//注册状态改变监听,获取服务器发送过来的数据
request.onreadystatechange = function(){
if(request.readyState == 4 && request.status == 200){
// alert(request.responseText);
var data = request.responseText;
if(data == 1){
document.getElementById("span01").innerHTML="<font color=red>用户名已存在</font>";
// alert("用户名已存在");
}else{
document.getElementById("span01").innerHTML="<font color=red>恭喜!用户名可以使用</font>";
// alert("恭喜!用户名可以使用")
}
}
}
request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
request.send("name="+name);
}
</script>

十七 Ajax&校验用户名功能的更多相关文章

  1. AJAX校验用户名是否存在,焦点离开用户名、点击 【 检 查用户名 】的校验。分别用 XMLHttp 和 JQueryAJAX实现。

     XMLHttp方法: $("#name").blur(function () { var xmlhttp = new ActiveXObject("Microsoft. ...

  2. Ajax校验用户名是否可用

    准备 导包:DBUtil,JDBC,C3P0 在src下导入c3p0-config.xml 导入JDBCUtil 创建数据库 第2.3.条查看https://blog.csdn.net/weixin_ ...

  3. Ajax详解及其案例分析------如何获得Ajax对象,使用Ajax对象发送GET和POST请求,校验用户名,POST和GET请求时的乱码处理,实现级联的下拉列表

    本节主要内容预览: 1 获得Ajax对象 2 使用Ajax对象发送GET请求 3 使用Ajax对象发送POST请求 4 使用Ajax校验用户名 5 POST请求时的乱码处理 6 GET请求时的乱码处理 ...

  4. ajax案例_校验用户名

    目录 ajax案例_校验用户名 代码下载 需求 流程 搭建环境 开发代码 1_jsp 1_servlet 1_service.dao 2_servlet 2_jsp 测试后,功能实现,完结撒花 aja ...

  5. 案例1.用Ajax实现用户名的校验

    用Ajax实现用户名的校验 java的验证类 public class UserDao { public boolean checkUserName(String name) { //这里的name是 ...

  6. 使用AJAX完成用户名是否存在异步校验

    一.JSP代码: 1.事件触发:onblur 2.编写AJAX代码:向Action中提交,传递username参数 <script> function checkUsername(){ / ...

  7. ajax实现用户名校验的传统和jquery的$.post方式

    第一种:传统的ajax异步请求,后台代码以及效果在最下边 首先我们在eclipse中创建一个注册页面regist.jsp,创建一个form表单,注意,由于我们只是实现用户名校验的效果,下边红色部门是我 ...

  8. SSH网上商城---使用ajax完成用户名是否存在异步校验

    小伙伴在上网的时候,需要下载或者观看某些视频资料,更或者是在逛淘宝的时候,我们都需要注册一个用户,当我们填写好各种信息,点击确定的时候,提示用户名已经存在,小编就想,为什么当我们填写完用户名的时候,她 ...

  9. 零基础学习java------35---------删除一个商品案例,删除多个商品,编辑(修改商品信息),校验用户名是否已经注册(ajax)

    一. 删除一个商品案例 将要操作的表格 思路图  前端代码 <%@ page language="java" contentType="text/html; cha ...

随机推荐

  1. 涂涂影院APP-免费VIP电影观看「安卓APP」

    最新下载链接:https://www.lanzous.com/u/niceyoo 2019年基本就没推广过这款APP,很失败,从第一版发布到现在涂涂影院已经做了2年了, 由于没有官网,所以基本百度能搜 ...

  2. BGR 与 HSV 模式的转换规则

    HSV模式中的H.S.V分别表示色调.饱和度.亮度 RGB转化到HSV的算法:max=max(R,G,B) min=min(R,G,B) if R = max, H = (G-B)/(max-min) ...

  3. Hive的学习之路(理论篇)

    一.Hive介绍 Apache官网给出的logo,一半是Hadoop大象的头,一半是蜜蜂的身体,也是寓意着它是基于Hadoop,哈哈,纯属个人理解,进入正题. Hive是基于Hadoop的一个数据仓库 ...

  4. LinkStack(链栈)

    链栈即链式栈,也就是说我们不用再考虑空间的大小,可随心所欲的进行数据的插入/删除了.和顺序栈一样,仍然要保持其stack的特性,只在一端进行插入和删除,后进先出. (2018-02-14 代码更新) ...

  5. JavaScript - map和parseInt的坑

    问题: var arrs = ['1', '2', '3']; var r = arrs.map(parseInt); alert(r);//1,NaN,NaN map arr.map(functio ...

  6. 变量的注释(python3.6以后的功能)

    有时候导入模块,然后使用这个变量的时候,却没点出后面的智能提示.用以下方法可以解决:https://www.cnblogs.com/xieqiankun/p/type_hints_in_python3 ...

  7. 第一周之Hadoop学习(一)

    首先根据网上的教程得搭建一个linux的环境,所以第一部分是下载虚拟机的过程. 参考博客:https://blog.csdn.net/hliq5399/article/details/78193113 ...

  8. 你是否还在写try-catch-finally?来使用try-with-resources优雅地关闭流吧

    前言 开发中,我们常常需要在最后进行一些资源的关闭.比如读写文件流等,常见的,我们会在最后的finally里进行资源的关闭.但是这种写法是很不简洁的.其实,早在JDK1.7就已经引入了try-with ...

  9. 进程fork

    fork用于父进程创建一个子进程 返回两次 返回-1表示错误 父进程中返回创建子进程的ID,大于0 返回0是表示进入子进程 创建的子进程会继承父进程的属性,比如打开的文件描述符.工作目录.根目录等等. ...

  10. Java基础 -4.6

    循环嵌套 乘法口诀表 public static void main(String[] args) { for(int x =1;x<10;x++) { for(int y=1;y<=x; ...