Springmvc處理ajax請(qǐng)求并返回json數(shù)據(jù)
①在springmvc方法上添加@ResponseBody注解,springmvc會(huì)將數(shù)據(jù)轉(zhuǎn)換成json并返回;
@ResponseBody //指定返回json數(shù)據(jù),不跳轉(zhuǎn)頁(yè)面
@RequestMapping("/list")
public List<User> list(User user){
System.out.println("獲取到異步請(qǐng)求數(shù)據(jù):"+user);
//todo 根據(jù)條件做數(shù)據(jù)庫(kù)查詢,返回結(jié)果集合
ArrayList<User> users=new ArrayList<>();
users.add(new User(1,"james",18,"男"));
users.add(new User(2,"姚明",40,"男"));
users.add(new User(3,"科比",46,"男"));
return users;
}
list.jsp頁(yè)面中代碼為:
<body>
<input type="button" id="btn" value="異步加載數(shù)據(jù)"/>
<script src="${pageContext.request.contextPath}/static/js/jquery-3.2.1.min.js"></script>
<script>
$(function ($) {
$("#btn").click(function () {
$.ajax({
url:"${pageContext.request.contextPath}/list",
type:"post",
data:{"name":"james","age":18},
dataType:"json",
success:function (result) {
alert("請(qǐng)求成功!")
console.log(result)
}
})
})
})
</script>
</body>
②如果contentType=”application/json”時(shí),在方法的參數(shù)前添加@RequestBody注解,獲取傳遞的json字符串,并封裝到對(duì)象中;
@ResponseBody //指定返回json數(shù)據(jù),不跳轉(zhuǎn)頁(yè)面
@RequestMapping("/list")
public List<User> list(@RequestBody(required=false) User user){
System.out.println("獲取到異步請(qǐng)求數(shù)據(jù):"+user);
//todo 根據(jù)條件做數(shù)據(jù)庫(kù)查詢,返回結(jié)果集合
ArrayList<User> users=new ArrayList<>();
users.add(new User(1,"james",18,"男"));
users.add(new User(2,"姚明",40,"男"));
users.add(new User(3,"科比",46,"男"));
return users;
}
list.jsp頁(yè)面中代碼為:
<body>
<input type="button" id="btn" value="異步加載數(shù)據(jù)"/>
<script src="${pageContext.request.contextPath}/static/js/jquery-3.2.1.min.js"></script>
<script>
$(function ($) {
$("#btn").click(function () {
var jsonObj={"name":"james","age":18};
$.ajax({
url:"${pageContext.request.contextPath}/list",
type:"post",
data:JSON.stringify(jsonObj),//json字符串 將json對(duì)象轉(zhuǎn)化為字符串
dataType:"json",
contentType:"application/json",//指定以json方式傳輸數(shù)據(jù)
success:function (result) {
alert("請(qǐng)求成功!")
console.log(result)
}
})
})
})
</script>
</body>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringMVC中處理Ajax請(qǐng)求的示例
- SpringMVC ajax請(qǐng)求的處理方法介紹
- Spring MVC中處理ajax請(qǐng)求的跨域問(wèn)題與注意事項(xiàng)詳解
- Springmvc ajax跨域請(qǐng)求處理方法實(shí)例詳解
- springMVC解決ajax請(qǐng)求亂碼的三種方法
- Spring MVC 中 AJAX請(qǐng)求并返回JSON的示例
- SpringMVC環(huán)境下實(shí)現(xiàn)的Ajax異步請(qǐng)求JSON格式數(shù)據(jù)
- Spring MVC 處理Ajax請(qǐng)求的方式詳解
相關(guān)文章
SpringBoot實(shí)現(xiàn)接口參數(shù)加密解密的示例代碼
加密解密本身并不是難事,問(wèn)題是在何時(shí)去處理?SpringMVC?中給我們提供了?ResponseBodyAdvice?和?RequestBodyAdvice,利用這兩個(gè)工具可以對(duì)請(qǐng)求和響應(yīng)進(jìn)行預(yù)處理,非常方便。廢話不多說(shuō),我們一起來(lái)學(xué)習(xí)一下2022-09-09
idea中啟動(dòng)項(xiàng)目彈出 IDEA out of memory窗口的解決方案
這篇文章主要介紹了idea中啟動(dòng)項(xiàng)目彈出 IDEA out of memory窗口的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
Springboot集成百度地圖實(shí)現(xiàn)定位打卡的示例代碼
本文主要介紹了Springboot集成百度地圖實(shí)現(xiàn)定位打卡的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-02-02
Java中字符串和byte數(shù)組之間的簡(jiǎn)單轉(zhuǎn)換方法
這篇文章主要給大家介紹了關(guān)于Java中字符串和byte數(shù)組之間的簡(jiǎn)單轉(zhuǎn)換方法,Java中將String類型轉(zhuǎn)換為byte[]類型,可以使用String的getBytes()方法,還有很多其他的辦法,需要的朋友可以參考下2023-08-08

