thymeleaf实现ajax请求的两种方式

简介: thymeleaf实现ajax请求的两种方式

注意,对应的Controller类不能使用@RestController注解。

使用fragment

1、布局中定义fragment和id,定义ajax请求


<body>

...

<div>

<h3>get请求</h3>

<p>

<button onclick="executeGetAjax('眼里有光,心里有梦')" type="button">发起ajax-get请求</button>

</p>

<div th:fragment="get-response" th:id="id-request-get">

<p th:text="${value_get}"></p>

</div>

</div>

<script type="text/javascript">

function executeGetAjax(name) {

<!-- data中传递json对象 -->

$.ajax({

url: '/execute/get-ajax1',

type: 'get',

async: true,

data: {

name

},

dataType: 'text',

success: function (data) {

alert(data);

console.log(data);

$("#id-request-get").html(data);

}

})

};

</script>

</body>

2、WebController中定义对应的ajax请求方法


/**

* ajax请求,get-同步更新页面内容

*

* @param name

* @return

*/

@RequestMapping(value = "/execute/get-ajax", method = {RequestMethod.GET})

public String executeGet(Model model, @RequestParam(value = "name", required = false, defaultValue = "猫了个咪") String name) {

model.addAttribute("value_get", "get ajax response:" + name);

return "request-methods::get-response";

}

具体参考:

https://www.thymeleaf.org/doc/tutorials/2.1/thymeleafspring.html#rendering-template-fragments

使用ModelAndView

布局方式同fragment方式,webController方法中有改动:


/**

* 使用 ModelAndView 实现ajax请求

* @param model

* @param name

* @return

*/

@RequestMapping(value = "/execute/get-ajax1", method = {RequestMethod.GET})

public ModelAndView executeGet1(Model model, @RequestParam(value = "name", required = false, defaultValue = "猫了个咪") String name) {

model.addAttribute("value_get", "get ajax response:" + name);

return new ModelAndView("request-methods::get-response");

}

具体参考:

https://stackoverflow.com/questions/20982683/spring-mvc-3-2-thymeleaf-ajax-fragments

项目地址

tinytongtong / spring-thymeleaf

相关文章
|
8月前
|
JSON 前端开发 JavaScript
axios请求成功而$.ajax却不行排错
axios请求成功而$.ajax却不行排错
67 2
|
8月前
|
前端开发
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
|
2月前
|
XML 前端开发 JavaScript
|
7天前
|
JSON 前端开发 JavaScript
Python中如何判断是否为AJAX请求
AJAX请求是Web开发中常见的异步数据交互方式,允许不重新加载页面即与服务器通信。在Python的Django和Flask框架中,判断AJAX请求可通过检查请求头中的`X-Requested-With`字段实现。Django提供`request.is_ajax()`方法,Flask则需手动检查该头部。本文详解这两种框架的实现方法,并附带代码示例,涵盖安全性、兼容性、调试及前端配合等内容,帮助开发者提升Web应用性能与用户体验。
28 0
|
3月前
|
JSON JavaScript 前端开发
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
73 22
|
3月前
|
前端开发 JavaScript
回顾前端页面发送ajax请求方式
回顾前端页面发送ajax请求方式
43 18
|
3月前
|
前端开发 JavaScript Java
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
95 4
|
3月前
|
前端开发 JavaScript 数据处理
JQuery 拦截请求 | Ajax 请求拦截
【10月更文挑战第4天】
142 1
|
4月前
|
前端开发
React技术栈-react使用的Ajax请求库实战案例
这篇文章介绍了在React应用中使用Axios和Fetch库进行Ajax请求的实战案例,展示了如何通过这些库发送GET和POST请求,并处理响应和错误。
65 10
|
4月前
|
前端开发
React技术栈-react使用的Ajax请求库用户搜索案例
这篇文章展示了一个React技术栈中使用Ajax请求库(如axios)进行用户搜索的实战案例,包括React组件的结构、状态管理以及如何通过Ajax请求获取并展示GitHub用户数据。
37 7
React技术栈-react使用的Ajax请求库用户搜索案例