JavaWeb之Ajax的基本使用與實(shí)戰(zhàn)案例
一、Ajax是什么?
Ajax,全稱Asynchronous JavaScript and XML ,也就是異步加載的javascript 和 XML
.Ajax是一種用于創(chuàng)建快速動(dòng)態(tài)網(wǎng)頁的技術(shù)。
通過在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,Ajax可以使網(wǎng)頁實(shí)現(xiàn)異步更新。這意味著可以在不重新加載整個(gè)網(wǎng)頁的情況下,對網(wǎng)頁的某部分進(jìn)行更新。
JavaScript:更新局部的網(wǎng)頁
XML:一般用于請求數(shù)據(jù)和響應(yīng)數(shù)據(jù)的封裝
XMLHttpRequest對象:發(fā)送請求到服務(wù)器并獲得返回結(jié)果
CSS:美化頁面樣式
異步:發(fā)送請求后不等返回結(jié)果,由回調(diào)函數(shù)處理結(jié)果
二、為什么使用Ajax?
??無刷新:不刷新整個(gè)頁面,只刷新局部
??無刷新的好處:只更新部分頁面,有效利用帶寬,提高用戶體驗(yàn)
三、Ajax基本使用
??通過 HTTP 請求加載遠(yuǎn)程數(shù)據(jù)。
1、$.ajax()
常用參數(shù) | 說明 |
url | 一個(gè)用來包含發(fā)送請求的URL字符串(請求地址) |
type | 請求方式 (“POST” 或 “GET“[默認(rèn)]) |
data | 發(fā)送到服務(wù)器的數(shù)據(jù)(參數(shù)) |
dataType | 預(yù)期服務(wù)器返回的數(shù)據(jù)類型(xml、json、text) |
dataType | 請求成功的回調(diào)函數(shù) |
error | 請求失敗的回調(diào)函數(shù) |
??通過遠(yuǎn)程 HTTP POST /GET請求載入信息。
這是一個(gè)簡單的 POST /GET請求功能以取代復(fù)雜 $.ajax 。請求成功時(shí)可調(diào)用回調(diào)函數(shù)。如果需要在出錯(cuò)時(shí)執(zhí)行函數(shù),請使用 $.ajax。
2、$.post()
常用參數(shù) | 說 明 |
url | 一個(gè)用來包含發(fā)送請求的URL字符串(請求地址) |
data | 發(fā)送到服務(wù)器的數(shù)據(jù)(參數(shù)) key/value |
success(data) | 請求成功的回調(diào)函數(shù) |
type | 返回內(nèi)容格式(xml、json、text等) |
3.$.get()
常用參數(shù) | 說 明 |
url | 一個(gè)用來包含發(fā)送請求的URL字符串(請求地址) |
data | 發(fā)送到服務(wù)器的數(shù)據(jù)(參數(shù)) key/value |
success(data) | 請求成功的回調(diào)函數(shù) |
type | 返回內(nèi)容格式(xml、json、text等) |
三種方法代碼如下:
$.get("url",data,fun(){},"text") $.post("url",data,fun(){},"text") $.ajax({ url:"", type:"get|post", data:{}, dataType:"", success(){} })
四、案例
無刷新登錄(ajax、get、post)
login.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html> <head> <title>Title</title> <script src="js/jquery-3.3.1.js"></script> <link rel="icon" href="Icon/bb.png" rel="external nofollow" type="text/x-icon"> </head> <body> <div> <p><input id="account" name="account"></p> <p><input id="password" name="password"></p> <button onclick="login()">登錄</button> </div> <script> function login() { //取到頁面的值 let account = $("#account").val() let password = $("#password").val() //通過jquery來發(fā)送請求ajax去后臺(tái) login.do //ajax方法:get|post $.ajax({ url:"login.do",//訪問地址 data:{account,password},//攜帶的數(shù)據(jù) dataType:"text",//希望后臺(tái)給你什么樣子的數(shù)據(jù) type: "get",//什么請求類型 success(resp){ if (resp.trim() === "yes") { alert("登陸成功") location.href = "index.jsp" } else { alert("登陸失敗") } },//成功 error(){ }//錯(cuò)誤 }) //get請求 /** $.get( //請求地址 "login.do", //攜帶過去的數(shù)據(jù) 直接放數(shù)據(jù),名字就是數(shù)據(jù)的名字 {account, password}, //回調(diào)函數(shù) 請求之后會(huì)調(diào)用這個(gè)函數(shù) //resp就是后臺(tái)給我的值 function (resp) { //trim 去空格 //contains 包含 if (resp.trim() === "yes") { alert("登陸成功") location.href = "index.jsp" } else { alert("登陸失敗") } }, "text" //希望后臺(tái)給我的是普通的文本 ) **/ /** $.get("url",data,fun(){},"text") $.post("url",data,fun(){},"text") $.ajax({ url:"", type:"get|post", data:{}, dataType:"", success(){} }) **/ } </script> </body> </html>
LoginServlet.java
ackage com.zking.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; @WebServlet("/login.do") public class LoginServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doPost(req,resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //獲取表單數(shù)據(jù) String account = req.getParameter("account"); String password = req.getParameter("password"); //調(diào)用biz去數(shù)據(jù)庫做驗(yàn)證 PrintWriter out = resp.getWriter(); if("root".equals(account)&&"root123".equals(password)){ out.println("yes"); }else{ out.println("no"); } } }
查詢名字是否存在
效果圖如下:
如果輸入的內(nèi)容在集合中有的話則提示用戶名已經(jīng)存在 并且按鈕禁用
若沒有則顯示??標(biāo)簽
register.java
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <html> <head> <title>Title</title> <script src="${pageContext.request.contextPath}/js/jquery-3.3.1.js"></script> <style> #tip{ color: red; } </style> </head> <body> <p><input id="name" onkeyup="yz()" type="text" placeholder="請輸入你的用戶名"><span id="tip"></span></p> <button id="register">去注冊</button> <script> function yz(){ //獲取數(shù)據(jù) let name=$("#name").val(); console.log(name) //發(fā)送請求 $.get("find.do",{name},(resp)=>{ if(resp.trim()==="true"){ $("#tip").text("用戶名已經(jīng)存在") $("#register").prop("disabled",true) }else{ $("#tip").text("????") $("#register").prop("disabled",false) } },"text") } </script> </body> </html>
FindServlet.java
package com.zking.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; import java.util.ArrayList; import java.util.List; /** * 驗(yàn)證用戶名是否存在 **/ @SuppressWarnings("all") @WebServlet("/find.do") public class FindServlet extends HttpServlet { //數(shù)據(jù)庫中存在的名字 List<String> list = new ArrayList<String>(); { list.add("小明"); list.add("小黃"); list.add("小黑"); list.add("小紫"); list.add("小綠"); } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doPost(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //去數(shù)據(jù)庫查詢 String name = req.getParameter("name"); boolean f=false; for (String n : list) { if(n.equals(name)){ f=true; break; } } //需要把結(jié)果告訴前臺(tái) PrintWriter out = resp.getWriter(); out.println(f); } }
使用搜索框時(shí)彈出的提示
效果圖如下:
index.java
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <title>Title</title> <script src="js/jquery-3.3.1.js"></script> </head> <body> ??<input id="keyWord" name="keyWord" onkeyup="search()"> <ul id="list"> </ul> <script> function search(){ //得到輸入框的值 let keyWord=$("#keyWord").val() //發(fā)送到負(fù)責(zé)檢索商品名稱的servlet $.get("search.do",{keyWord},(resp)=>{ //清空原來的選項(xiàng) $("#list").empty() //resp現(xiàn)在是從字符串變成了數(shù)組 for(let n of resp){//foreach $("#list").append("<li>"+n+"</li>") } },"json"); } //json //對象的字符串格式,json有固定的格式 //將對象變成json //將json還原為對象 </script> </body> </html>
SearchServlet.java
package com.zking.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 com.fasterxml.jackson.databind.ObjectMapper; import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; /** * 查詢出對應(yīng)關(guān)鍵字的商品名稱 **/ @WebServlet("/search.do") public class SearchServlet extends HttpServlet { //數(shù)據(jù)庫中存在的商品名字 List<String> list = new ArrayList<String>(); { list.add("楊枝甘露"); list.add("珍珠奶茶"); list.add("焦糖奶茶"); list.add("雀巢咖啡"); list.add("蜜桃四季春"); } @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doPost(req, resp); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //去數(shù)據(jù)庫查詢 String keyWord = req.getParameter("keyWord"); //新建一個(gè)集合 List<String> ns=new ArrayList<String>(); for (String n : list) { if(n.contains(keyWord)){ ns.add(n); } } //設(shè)置響應(yīng)的編號 resp.setCharacterEncoding("utf-8"); //需要把結(jié)果告訴前臺(tái) PrintWriter out = resp.getWriter(); //需要將集合變成json //1.需要獲取轉(zhuǎn)換對象 ObjectMapper mapper=new ObjectMapper(); //2.調(diào)用方法 String str = mapper.writeValueAsString(ns); out.println(str); } }
注意: 遍歷出來的集合要變成jsno字符串
總結(jié)
到此這篇關(guān)于JavaWeb之Ajax的基本使用與案例的文章就介紹到這了,更多相關(guān)JavaWeb Ajax基本使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaCV實(shí)現(xiàn)圖片中人臉檢測的示例代碼
這篇文章主要介紹了如何利用JavaCV實(shí)現(xiàn)圖片中人臉檢測的功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以了解一下2022-11-11如何批量測試Mybatis項(xiàng)目中的Sql是否正確詳解
這篇文章主要給大家介紹了關(guān)于如何批量測試Mybatis項(xiàng)目中Sql是否正確的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12如何利用Java輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn)
這篇文章主要給大家介紹了關(guān)于如何利用Java輸出鏈表中倒數(shù)第k個(gè)結(jié)點(diǎn)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-12-12java 操作gis geometry類型數(shù)據(jù)方式
這篇文章主要介紹了java 操作gis geometry類型數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java設(shè)計(jì)模式之外觀模式(Facade)
這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)模式之外觀模式Facade的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01Java中關(guān)鍵字synchronized的使用方法詳解
synchronized關(guān)鍵字可以作為函數(shù)的修飾符,也可作為函數(shù)內(nèi)的語句,也就是平時(shí)說的同步方法和同步語句塊,下面這篇文章主要給大家介紹了關(guān)于Java中synchronized使用的相關(guān)資料,需要的朋友可以參考下2021-08-08簡單了解Java多態(tài)向上轉(zhuǎn)型相關(guān)原理
這篇文章主要介紹了簡單了解Java多態(tài)向上轉(zhuǎn)型相關(guān)原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12