欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaWeb之Ajax的基本使用與實(shí)戰(zhàn)案例

 更新時(shí)間:2022年08月02日 09:55:47   作者:時(shí)宜  
ajax技術(shù)是使頁面能局部刷新的一種技術(shù),下面這篇文章主要給大家介紹了關(guān)于JavaWeb之Ajax的基本使用與實(shí)戰(zhàn)案例的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、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)文章

  • 淺談list.removeAll()刪除失敗的原因及解決

    淺談list.removeAll()刪除失敗的原因及解決

    這篇文章主要介紹了淺談list.removeAll()刪除失敗的原因及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • JavaCV實(shí)現(xiàn)圖片中人臉檢測的示例代碼

    JavaCV實(shí)現(xiàn)圖片中人臉檢測的示例代碼

    這篇文章主要介紹了如何利用JavaCV實(shí)現(xiàn)圖片中人臉檢測的功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以了解一下
    2022-11-11
  • java 字浮串提取方法匯集

    java 字浮串提取方法匯集

    用方法toCharArray public char[] toCharArray()
    2008-10-10
  • 如何批量測試Mybatis項(xiàng)目中的Sql是否正確詳解

    如何批量測試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)

    如何利用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-12
  • java 操作gis geometry類型數(shù)據(jù)方式

    java 操作gis geometry類型數(shù)據(jù)方式

    這篇文章主要介紹了java 操作gis geometry類型數(shù)據(jù)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • java設(shè)計(jì)模式之外觀模式(Facade)

    java設(shè)計(jì)模式之外觀模式(Facade)

    這篇文章主要為大家詳細(xì)介紹了java設(shè)計(jì)模式之外觀模式Facade的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 淺析Java 9 Optional API 新增方法

    淺析Java 9 Optional API 新增方法

    本文我們介紹了Java 9 Optional Api新增的三個(gè)方法。or方法在Optional為空時(shí)返回Optional對象。 ifPresentOrElse()在值存在時(shí)執(zhí)行Consumer參數(shù),反之執(zhí)行另一個(gè)參數(shù)回調(diào)參數(shù)。感興趣的朋友跟隨小編一起看看吧
    2019-12-12
  • Java中關(guān)鍵字synchronized的使用方法詳解

    Java中關(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)原理

    這篇文章主要介紹了簡單了解Java多態(tài)向上轉(zhuǎn)型相關(guān)原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12

最新評論