Ajax知识点

这篇博客探讨了AJAX(异步JavaScript和XML)技术在实现网页异步刷新中的应用。首先介绍了AJAX的基本概念,然后详细分析了AJAX操作的各个步骤,并提供了学习资源。对于如何创建JSP页面的问题,作者提到了使用Eclipse并提供了解决方案。
摘要由CSDN通过智能技术生成

通过AJAX( Asynchronous JavaScript And XML) 实现异步刷新

问题:如何建立一个JSP页面,步骤过程?这里留疑                                     

——已解决,利用eclipse,收藏问题里有详细答题

一、认识AJAX

用于用户名校验的页面

准备一个JSP页面,叫做checkName.jsp用于校验提交的用户名是否存在
如果提交的用户名是abc就打印存在,否则就可以使用

<html>
<a href="https://how2j.cn/study/checkName.jsp?name=abc">checkName.jsp?name=abc</a>
<br>
<a href="https://how2j.cn/study/checkName.jsp?name=def">checkName.jsp?name=def</a>
</html>
不使用AJAX 通过刷新页面验证账号是否存在<form action="https://how2j.cn/study/checkName.jsp">
 
输入账号 <input name="name" type="text" value="abc">
 
<input type="submit" value="验证账号是否存在">
 
</form>
使用AJAX 通过无刷新验证账号是否存在<span>输入账号 :</span>
<input id="name" name="name" οnkeyup="check()" type="text"> 
<span id="checkResult"></span>
 
<script>
var xmlhttp;
function check(){
  var name = document.getElementById("name").value;
  var url = "https://how2j.cn/study/checkName.jsp?name="+name;
 
  xmlhttp =new XMLHttpRequest();
  xmlhttp.onreadystatechange=checkResult; //响应函数
  xmlhttp.open("GET",url,true);   //设置访问的页面
  xmlhttp.send(null);  //执行访问
}
 
function checkResult(){
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
  

</script>

二、 分布分析AJAX每个步骤(学习与网页,已标注)

AJAX 请求和相应图示

创建XHR

创建XHR对象 XMLHttpRequest
XHR对象是一个javascript对象,它可以在用户没有感觉的情况下,就像背后运行的一根小线程一般,悄悄的和服务器进行数据交互
AJAX就是通过它做到无刷新效果的

<script>
var xmlhttp =new XMLHttpRequest();
document.write(xmlhttp);
</script>
设置响应函数

XHR对象的作用是和服务器进行交互,所以既会发消息给服务器,也能接受服务器返回的响应。
当服务器响应回来的时候,调用怎么处理呢?
通过 xmlhttp.onreadystatechange=checkResult 就可以指定用checkResult 函数进行处理。

设置并发出请求

通过open函数设置背后的这个小线程,将要访问的页面url ,在本例中就是    /study/checkName.jsp

xmlhttp.open("GET",url,true);


通过send函数进行实际的访问

xmlhttp.send(null);


null表示没有参数,因为参数已经通过“GET" 方式,放在url里了。
只有在用"POST",并且需要发送参数的时候,才会使用到send。
类似这样:
xmlhttp.send("user="+username+"&password="+password)

处理响应信息

在checkResult 函数中处理响应

function checkResult(){

if (xmlhttp.readyState==4 && xmlhttp.status==200)

document.getElementById('checkResult').innerHTML=xmlhttp.responseText;

}

xmlhttp.readyState 4 表示请求已完成
xmlhttp.status 200 表示响应成功
xmlhttp.responseText; 用于获取服务端传回来的文本
document.getElementById('checkResult').innerHTML 设置span的内容为服务端传递回来的文本

checkName.jsp

先简单了解一下,后面学习JSP,现在不怎么懂

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8" isELIgnored="false"%>
 
<%
    String name = request.getParameter("name");
     
    if("abc".equals(name))
        out.print("<font color='red'>已经存在</font>");
    else
        out.print("<font color='green'>可以使用</font>");
     
%>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值