簡單介紹ajax

来源:https://www.cnblogs.com/wp9503/archive/2019/08/01/11285155.html
-Advertisement-
Play Games

1.簡述 AJAX(Asynchronous Javascript And XML),是一個局部刷新技術,即網頁不需要重新載入,只進行部分更新即可 例如:視頻彈幕,點贊,登錄驗證... 2.JavaScript原生AJAX 步驟: 1.創建XMLHttpRequest核心對象; var 變數名 = ...


1.簡述

AJAX(Asynchronous Javascript And XML),是一個局部刷新技術,即網頁不需要重新載入,只進行部分更新即可

例如:視頻彈幕,點贊,登錄驗證...

2.JavaScript原生AJAX

步驟:

  1.創建XMLHttpRequest核心對象;

    var 變數名 = new XMLHttpReques();

  2.使用核心對象打開請求;

    變數名.open(參數一,參數二,參數三);

      參數一:數據提交方式(get或者post)

      參數二:請求地址

      參數三:是否非同步(true[預設]非同步,false)

  3.使用核心對象發送請求;

    變數名.send();

  4.接收數據.

    變數名.onreadystatechange = function(){...}

代碼示例:

html:

<script type="text/javascript">
function jsajax(){
    var xhr = new XMLHttpRequest();
    xhr.open("post","JsAjax",true);
    xhr.send();
    xhr.onreadystatechange = function(){
        if(xhr.status == 200 && xhr.readyState == 4){
            var i = xhr.responseText;
            document.getElementById("msg").innerText=i;            
        }
    }
}
</script>
</head>
<body>
jsajax:<span id="msg"></span>
<br>
<button onclick="jsajax()">點我有驚喜</button>
</body>
</html>

java

//因為ajax可以獲取響應主題的內容,所以採用PrintWriter返回數據
PrintWriter writer = response.getWriter(); writer.print("JS原生AJAX");

原生AJAX使用起來十分麻煩,一般只需要瞭解即可,更多的是使用下麵JQ版的AJAX.

3.JQuery版AJAX

JQuery版AJAX有三種寫法,下麵一一介紹這三種寫法

第一種:

$.ajax({

  url:"請求路徑",

  data:{"鍵名1":值1,"鍵名2":值2,"鍵名3":值3......},

  type:"提交方式get/post",

  dataType:"返回數據格式",(常用:text,json)

  async:true/false,

  success:function(){},

  error:function(){}

})

url:請求路徑;data:請求數據;type:數據請求方式;dataType:返回數據格式;async:是否非同步;success:執行成功執行本函數;error:執行失敗執行本函數

代碼示例:

$.ajax({
    url:"JQAjax",
    data:{"name":"李四","age":24},
    type:"post",
    dataType:"text",
    async:true,
    success:function(obj){
        $("#msg").text(obj);
    }
})

 

第二種&第三種:

第二種和第三種是將提交方式分解出來,$.get()和$.post()內容基本一致

$.get(

  "請求路徑",(對應第一種方式url)

  {"鍵名1":值1,"鍵名2":值2,"鍵名3":值3......},(對應data)

  function(){},(對應success:function(){})

  "返回數據格式"(對應dataType)

)

$.post(

  "請求路徑",

  {"鍵名1":值1,"鍵名2":值2,"鍵名3":值3......},

  function(){},

  "返回數據格式"

)

代碼示例:

$.get(
    "JQPostAjax",
    {"name":"張三","age":23},
    function(obj){
        $("#msg").text(obj);
    },
    "text"
);
$.post(
    "JQPostAjax",
    {"name":"張三","age":23},
    function(obj){
        $("#msg").text(obj);
    },
    "text"
);

 4.json

  • 概述:json是一種有格式的字元串,是輕量級的數據傳輸方式.

json數據格式(三種)

  1.數組

    [值1,值2,值3......]

    值的數據類型隨意

  2.對象

    {"鍵名1":值1,"鍵名2":"值2"......}

  3.混合模式

    [{對象1},{對象2},{對象3}.....]

    {[數組1],[數組2],[數組3]......}

    這裡只是簡單敘述了混合模式的兩種寫法,實際寫法並不固定,只要嵌套正確({}和[]交替使用),就OK.

  例如:

{
  "zone":"boss",
  "persons":[
    {"name":"張三","age":23,"sroce":[98,99,100]},
    {"name":"李四","age":24,"sroce":[87,87,87]},
    {"name":"王五","age":25,"sroce":[76,876,65]}
  ]
}

5.jackson

作用:jackson將數組,集合,對象...轉換成json格式

使用方式:

  1.創建ObjectMapper對象

    ObjectMapper 對象名 = new ObjectMapper();

  2.將指定的數據轉化為json

    String 變數名 = 對象名.writeValueAsString("指定的數據");

代碼示例:

Student s1 = new Student("張三", 23, new int[]{93,94,95});
Student s2 = new Student("李四", 24, new int[]{94,95,96});
Student s3 = new Student("王五", 25, new int[]{95,96,97});
Student s4 = new Student("趙六", 26, new int[]{96,97,98});
Student s5 = new Student("孫七", 27, new int[]{97,98,99});
List<Student> students = new ArrayList<Student>();
students.add(s1);
students.add(s2);
students.add(s3);
students.add(s4);
students.add(s5);
//轉化為json
/*
 * 1.創建ObjectMapper對象
 * 2.使用writeValueAsString將數據轉化為json格式
 */
ObjectMapper mapper = new ObjectMapper();
String json = mapper.writeValueAsString(students);

response.setContentType("text/html;charset=utf-8");
PrintWriter writer = response.getWriter();
writer.print(json);

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、部署啟動activiti 1、部署,將兩個war包拷貝到Tomcat下即可。 2、啟動tomcat,訪問http://127.0.0.1:8080/activiti app 預設賬號密碼:admin test 二、修改數據連接和密碼 1、可以直接在頁面上修改密碼,但是重啟後就還原了,這是因為預設 ...
  • 一、logging模塊講解 1.函數:logging.basicConfig() 參數講解: (1)level代表高於或者等於這個值時,那麼我們才會記錄這條日誌 (2)filename代表日誌會寫在這個文件之中,如果沒有這個欄位則會顯示在控制臺上 (3)format代表我們的日誌顯示的格式自定義,如 ...
  • 1.Spring AOP中的基本概念 連接點(Joinpoint):在程式執行過程中某個特定的點,比如某方法調用的時候或者處理異常的時候。在Spring AOP中,一個連接點總是表示一個方法的執行。 通俗的講: 層與層之間調用的過程中,目標層中可供調用的方法,就稱之為連接點。 切入點(Pointcu ...
  • 特殊的算數運算符 以上算術運算符均有對應的賦值運算符: /= //= **= 邏輯運算符 返回值均為bool型。 成員運算符 適用於字元串,列表或元組的成員判斷,返回值均為bool型。 ...
  • 1.synchronized的3種用法 (1)修飾實例方法,作用於當前對象實例加鎖,進入同步代碼前要獲得當前對象實例的鎖(2)修飾靜態方法,作用於當前類對象加鎖,進入同步代碼前要獲得當前類對象的鎖 。也就是給當前類加鎖,會作用於類的所有對象實例,因為靜態成員不屬於任何一個實例對象,是類成員( sta ...
  • Python 可通過 if 語句來實現三目運算的功能,因此可以近似地把這種 if 語句當成三目運算符。作為三目運算符的 if 語句的語法格式如下: 三目運算的規則是:先對邏輯表達式 expression 求值,如果邏輯表達式返回 True,則執行並返回 True_statements 的值;如果邏輯 ...
  • 這是第四個的輸出 ...
  • 不需要導入模塊(內置函數) math模塊 需要先導入math模塊,然後以 math.常量名/函數名的方式調用。 數學常量 e π sin(x)、cos(x)、tan(x) degrees(x) e的x次方 序列指的是列表(List)、元組(Tuple)、字元串(String)。 序列,是有序的,集合 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...