佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > ajax實現(xiàn)簡單實時驗證功能

ajax實現(xiàn)簡單實時驗證功能

熱門標(biāo)簽:Mysql連接數(shù)設(shè)置 阿里云 銀行業(yè)務(wù) 科大訊飛語音識別系統(tǒng) 電子圍欄 服務(wù)器配置 團購網(wǎng)站 Linux服務(wù)器

什么是ajax

Ajax 即“Asynchronous Javascript And XML”(異步 JavaScript 和 XML),是指一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)。

Ajax = 異步 JavaScript 和 XML(標(biāo)準(zhǔn)通用標(biāo)記語言的子集)。

Ajax 是一種用于創(chuàng)建快速動態(tài)網(wǎng)頁的技術(shù)。

Ajax 是一種在無需重新加載整個網(wǎng)頁的情況下,能夠更新部分網(wǎng)頁的技術(shù)。

 通過在后臺與服務(wù)器進行少量數(shù)據(jù)交換,Ajax 可以使網(wǎng)頁實現(xiàn)異步更新。這意味著可以在不重新加載整個網(wǎng)頁的情況下,對網(wǎng)頁的某部分進行更新。

傳統(tǒng)的網(wǎng)頁(不使用 Ajax)如果需要更新內(nèi)容,必須重載整個網(wǎng)頁頁面。

這是百度對它的定義,足夠詳細。
 值得補充的一點是對異步的理解,異步是相對于同步來說的,在這里他們指的是服務(wù)器和瀏覽器的交互模式。

 同步,每次請求發(fā)出之后,用戶操作即被阻塞,必須要求返回響應(yīng)后繼續(xù)操作。而異步指的是發(fā)出請求后,用戶無需等待響應(yīng),一切由ajax來實現(xiàn),無需進行刷新網(wǎng)頁就可以局部更新數(shù)據(jù)。提高了倆端的溝通效率。

來個小demo

做一個無刷新驗證表單的demo,在對話框中輸入用戶名,在后臺進行驗證,使用ajax技術(shù)。

項目結(jié)構(gòu),使用maven構(gòu)建

login.jsp

%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
html>
head>
  title>login/title>
/head>
body>

歡迎登陸:

    用戶名:input type="text" name="username" id="username" onchange="CallServer()"/>
    !-- 顯示提示信息 -->
    div id="msg">/div>
    !-- 在jsp頁面中引入js,絕對路徑的方式 -->
    script src="${pageContext.request.contextPath}/js/main.js">/script>
/body>
/html>

main.js

alert("use ajax!")
//創(chuàng)建XMLHttpRequest對象,在不同瀏覽器
function createXMLHTTP() {
  if(window.XMLHttpRequest){
    // IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執(zhí)行代碼
    xmlhttp = new XMLHttpRequest();
  }else {
    // IE6, IE5 瀏覽器執(zhí)行代碼
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
  }
  return xmlhttp;
}
function CallServer() {
  var username = document.getElementById("username").value;
  // 判斷為空
  if ((username == null) || (username == "")) return;
  var xmlhttp = createXMLHTTP();
  // 構(gòu)建請求url
  var url = "/loginServlet"+"?"+"username="+username;
  //狀態(tài)碼改變調(diào)用事件
  xmlhttp.onreadystatechange = function () {
    //正常返回,替換msg內(nèi)容
    if(xmlhttp.readyState == 4  xmlhttp.status == 200){
      document.getElementById("msg").innerHTML = xmlhttp.responseText;
    }
  }
  //異步提交請求
  xmlhttp.open("GET",url,true);
  //發(fā)送請求
  xmlhttp.send();
}

web.xml

!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >
web-app>
 display-name>Archetype Created Web Application/display-name>
 welcome-file-list>
  welcome-file>index.jsp/welcome-file>
 /welcome-file-list>
 servlet>
  servlet-name>loginServlet/servlet-name>
  servlet-class>com.lbw.servlet.loginServlet/servlet-class>
 /servlet>
 servlet-mapping>
  servlet-name>loginServlet/servlet-name>
  url-pattern>/loginServlet/url-pattern>
 /servlet-mapping>
/web-app>

loginServlet.java

package com.lbw.servlet;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
/**
 * 后端使用Servlet處理請求
 */
public class loginServlet extends HttpServlet {
  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    //設(shè)置編碼和響應(yīng)頭
    request.setCharacterEncoding("UTF-8");
    response.setContentType("text/xml;charset=UTF-8");
    response.setHeader("Cache-Control", "no-cache");
    //獲取參數(shù)
    String username = request.getParameter("username");
    String msg = "";
    if("lbw".equals(username)){
      msg = "名稱正確";
    }else {
      msg = "名稱錯誤";
    }
    PrintWriter out = response.getWriter();
    out.println(msg);
  }
  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    doPost(request,response);
  }
}

開始測試

輸入localhost:8888/login.jsp,彈出窗口

 代表在jsp中引入js成功

在輸入框輸入測試數(shù)據(jù)

 由Servlet中邏輯決定,返回錯誤信息

 由Servlet中邏輯決定,返回成功信息

由此,初步實現(xiàn)了ajax異步請求,達到了實時驗證的要求

一些小細節(jié)

1.在使用maven構(gòu)建項目,注意Project Structure -> Facets,這里設(shè)置web.xml和webapp的路徑,idea會使用到

2.在引入js時,注意使用相對路徑的方式來進行映入,并且用到EL表達式要開啟isELIgnored="false"·`避免沒有解析。

總結(jié)

以上所述是小編給大家介紹的ajax實現(xiàn)簡單實時驗證功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!

您可能感興趣的文章:
  • PHP+Ajax實現(xiàn)驗證碼的實時驗證
  • php+ajax注冊實時驗證功能
  • jquery+ajax實現(xiàn)注冊實時驗證實例詳解
  • Ajax實時驗證用戶名/郵箱等是否已經(jīng)存在的代碼打包

標(biāo)簽:蚌埠 衡水 江蘇 棗莊 萍鄉(xiāng) 衢州 廣元 大理

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ajax實現(xiàn)簡單實時驗證功能》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    平塘县| 都昌县| 永吉县| 永清县| 花莲市| 库尔勒市| 嘉义市| 汨罗市| 石泉县| 宁陵县| 旬邑县| 尚志市| 隆安县| 北辰区| 富民县| 株洲县| 绥宁县| 富平县| 克拉玛依市| 枣阳市| 新巴尔虎右旗| 桂林市| 右玉县| 盘锦市| 临桂县| 伊川县| 阜宁县| 博爱县| 通化县| 平罗县| 龙口市| 康平县| 新源县| 鸡西市| 贵州省| 景泰县| 江都市| 故城县| 揭东县| 繁昌县| 德保县|