【JavaWeb-jQuery】筆記(3)--- jQuery中給dom對象綁定事件;通過jQuery實現Ajax請求的處理

来源:https://www.cnblogs.com/Burning-youth/archive/2022/03/30/16077605.html
-Advertisement-
Play Games

要求:通過 jQuery 優化網站源代碼中的發送 Ajax 請求部分 ...


1、jquery 中給 dom對象綁定事件:


語法一:

  • $(選擇器).事件名稱( 事件的處理函數);
  • $(選擇器):定位 dom 對象,dom 對象可以有多個,一同綁定事件
  • 事件名稱:就是 js 中事件去掉 on 後的部分,例如 js 中的單擊事件 onclick(),對應 jquery 中的事件名稱 --- click
  • 事件的處理函數:就是一個 function,當事件發生時,會調用這個函數
  • 慄子:
//給id是btn的按鈕綁定單擊事件
$("#btn").click(funtion(){
    alert("btn按鈕單擊了");
})

 

語法二:

  • $(選擇器).on( 事件名稱 , 事件的處理函數);
  • 慄子:
//給id是btn的按鈕綁定單擊事件
$("#btn").on("click",function() { 處理按鈕單擊事件 } );

 

代碼練習:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<style type="text/css">
			div{
				background: yellow;
				width: 500px;
				height: 300px;
			}
		</style>
		<script type="text/javascript" src="js/jquery-3.6.0.js"></script>
		<script type="text/javascript">
			$(function(){
				$(":button").click(function(){
					//使用append增加dom對象
					$("div").append("<input id='newBtn' type='button' value='我是新來的按鈕,來點我啊 ~ '/>");
					//使用on函數給按鈕綁定事件
					$(":button").on("click",function(){
						alert("您可真帥 ~ ~    (❁´◡`❁)");
					})
				})
				
			})
		</script>
	</head>
	<body>
		<div></div>
		<input type="button" value="利用on函數,給div創建一個子對象(button),再給按鈕綁定一個click" />
		<br/>
		
	</body>
</html>

 

2、使用 jquery 的函數,實現 ajax 請求的處理:


  • 使用 XMLHttpRequest 實現 ajax ,有4個步驟,jquery 簡化了 ajax 請求的處理
  • jQuery 中提供了三個函數可以實現ajax請求的處理:
//$.post()和$.get() 的內部都調用了 $.ajax() 
$.ajax();//jquery中實現ajax的核心函數。

$.post();//使用post方式做ajax請求。

$.get();//使用get方式發送ajax請求。

 

  • $.ajax( { name:value, name:value, ... } );
  • $.ajax 函數的參數表示請求的url, 請求的方式,參數值等信息
  • $.ajax() 中的每一個參數都是 json中的 數據,包含請求方式,數據,回調方法等

參數介紹:

  •  主要使用的是 url , data ,dataType, success 。

async : 布爾值,表示請求是否非同步處理,預設是 true【可以不寫】。

contentType :發送數據到伺服器時所使用的內容類型【可以不寫】。

data:表示要發送到伺服器的數據,可以是 string,數組,json。

dataType:表示 期望從伺服器端返回的數據格式,可選的有: xml , html ,text ,json;當我們使用 $.ajax() 發送請求時, 會把 dataType 的值發送給伺服器, 那我們的 servlet 能夠讀取到 dataType的值,就知道你的瀏覽器需要的是 json 或者 xml 的數據,那麼伺服器就可以返回你需要的數據格式。

error(xhr,status,error):如果請求失敗要運行的函數,,其中 xhr, status, error 是自定義的形參名(xhr 是 XMLHttpRequest 對象)【可以不寫】。

success(result,status,xhr):當請求成功時運行的函數,其中 result, status, xhr 是自定義的形參名(xhr 是 XMLHttpRequest 對象),對應之前的 XMLHttpRequest 對象(readyState==4 && status==200)。

type:規定請求的類型(get 或 post ),預設是 get【可以不寫】。

url:請求的地址。

 

代碼練習:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>$Title$</title>
    <!--先載入jQuery工具包-->
    <script type="text/javascript" src="js/jquery-3.6.0.js"></script>
    <script type="text/javascript">
        $(function () {
            $("#btn").click(function () {
                //獲取省份id
                var id = $("#provinceId").val();
                //發起Ajax請求
                $.ajax({
                    url: "queryProvinceMessage",
                    data: {
                        "provinceId": id,
                    },
                    dataType: "json",
                    success: function (resp) {
                        //resp是json對象
                        //將服務端數據打回到相應的文本框中
                        $("#provinceName").val(resp.provinceName);
                        $("#provinceJianCheng").val(resp.jianCheng);
                        $("#provinceShengHui").val(resp.shengHui);
                    }
                });
            });
        })

    </script>
</head>
<body>
<p>通過省份ID來獲取省份信息</p>
<table>
    <tr>
        <td>省份編號:</td>
        <td>
            <input type="text" id="provinceId">
            <input type="button" value="搜索" id="btn">
        </td>
    </tr>

    <tr>
        <td>省份名稱:</td>
        <td><input type="text" id="provinceName"></td>
    </tr>

    <tr>
        <td>省份簡稱:</td>
        <td><input type="text" id="provinceJianCheng"></td>
    </tr>
    <tr>
        <td>省會名稱:</td>
        <td><input type="text" id="provinceShengHui"></td>
    </tr>
</table>
</body>
</html>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在實際項目中其中一部分邏輯可能會因為調用了外部服務或者等待鎖等情況下出現不可預料的異常,在這個時候我們可能需要對調用這部分邏輯進行重試,代碼裡面主要就是使用for迴圈寫一大坨重試的邏輯,各種硬編碼,各種辣眼睛的補丁。 ...
  • Python如何加密解密?感興趣的小伙伴可以舉一下腳,我看看有多少。咳咳咳,正式開始了,今天給大家分享的是Python如何加密解密,感興趣的小伙伴要認真學起來。 前言 加密演算法主要分為:哈希演算法、對稱加密演算法、非對稱加密演算法。 •哈希演算法:MD5、SHA256 •對稱加密演算法:DES、AES、CBC ...
  • 一、需求:創建一個HashMap集合,鍵是學號(String),值是學生對象(Student),存儲三個鍵值對元素,並遍歷 分析: 1.定義學生類 2.創建HashMap集合對象 3.創建學生對象 4把學生添加到集合中 5.遍歷集合 public class StudentDemo { public ...
  • 前言: 請各大網友尊重本人原創知識分享,謹記本人博客:南國以南i 上篇我們介紹到 保姆教程系列一、Linux搭建Nacos 註冊中心原理 一、環境準備 Java版本:1.8+ (Linux centos7虛擬機下安裝Jdk1.8) MySQL服務:5.6.5+ (Linux Centos7 安裝My ...
  • 遞歸:方法定義中調用方法本身的現象 註意事項: * A:遞歸一定要有出口,否則就是死遞歸 * B:遞歸的次數不能太多,否則就記憶體溢出 * C:構造方法不能遞歸使用 階乘案例 package cn.itcast_02; /* * 需求:請用代碼實現求5的階乘。 * 下麵的知識要知道: * 5! = 1 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 另有一篇我的字元編碼本質入門的文章見這裡:https://www.cnblogs.com/uncleguo/p/16008551.html 實話說,作為一個多年Java老年程式員,直到近來,在沒有決心花時間搞清楚Java String的編碼相關問題之前, 自己也都還是似懂非懂,一臉懵逼的。設想如果在 ...
  • 一、前言 好想看電視啊!!沒有會員,怎麼辦啊?想線上觀看或下載愛奇藝、PPTV、優酷、網易公開課、騰訊視頻、搜狐視頻、樂視、土豆、A站、B站等主流視頻網站的VIP視頻?又不想充會員怎麼辦?今天給你分享Python小技巧,實現你的VIP看電視的夢想。 PS:本軟體只用來交流學習,請勿用於商業用途。如涉 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...