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

相关文章
|
7月前
|
JSON 前端开发 JavaScript
axios请求成功而$.ajax却不行排错
axios请求成功而$.ajax却不行排错
61 2
|
7月前
|
前端开发
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
解决前端ajax跨域请求不携带cookie信息JSESSIONID的问题
|
23天前
|
XML 前端开发 JavaScript
|
2月前
|
JSON JavaScript 前端开发
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
《进阶篇第6章:vue中的ajax》包括回顾发送ajax请求方式、vue-cli脚手架配置代理服务器、vue-resource
59 22
|
2月前
|
前端开发 JavaScript
回顾前端页面发送ajax请求方式
回顾前端页面发送ajax请求方式
38 18
|
2月前
|
前端开发 JavaScript Java
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
第6章:Vue中的ajax(包含:回顾发送ajax请求方式、vue-cli脚手架配置代理服务器)
74 4
|
2月前
|
前端开发 JavaScript 数据处理
JQuery 拦截请求 | Ajax 请求拦截
【10月更文挑战第4天】
97 1
|
3月前
|
前端开发
React技术栈-react使用的Ajax请求库实战案例
这篇文章介绍了在React应用中使用Axios和Fetch库进行Ajax请求的实战案例,展示了如何通过这些库发送GET和POST请求,并处理响应和错误。
59 10
React技术栈-react使用的Ajax请求库实战案例
|
3月前
|
前端开发
React技术栈-react使用的Ajax请求库用户搜索案例
这篇文章展示了一个React技术栈中使用Ajax请求库(如axios)进行用户搜索的实战案例,包括React组件的结构、状态管理以及如何通过Ajax请求获取并展示GitHub用户数据。
33 7
React技术栈-react使用的Ajax请求库用户搜索案例
|
3月前
|
JSON JavaScript 前端开发
Jquery常用操作汇总,dom操作,ajax请求
本文汇总了jQuery的一些常用操作,包括DOM元素的选择、添加、移除,表单操作,以及如何使用jQuery发送Ajax请求,涵盖了GET、POST请求和文件上传等常见场景。