Thymeleaf网页中JS获取后台Model传递的数组列表
需积分: 50 23 浏览量
更新于2024-09-07
收藏 2KB TXT 举报
"在 Thymeleaf 网页中,JS 获取 Model 中的数组列表"
在 Thymeleaf 网页中,JS 获取后台 Model 传递过来的对象非常重要,这对减少数据库表操作代码的工作量,以及使前台开发更具灵活性具有非常重要的作用。获取 Model 传过来的简单变量很简单,但是获取它传过来的对象却不容易。本例中,我们将介绍如何在 Thymeleaf 网页中使用 JS 获取后台通过 Model 传递过来的数组列表。
在 Thymeleaf 中,我们可以使用 Model 来传递数据给视图层。在 Controller 中,我们可以使用 `@RequestMapping` 注解来映射请求,并将数据添加到 Model 中。在本例中,我们使用 `ArrayList` 来存储数组列表, 并将其添加到 Model 中。
在 Controller 中的代码如下所示:
```java
@RequestMapping("/user")
public String userHandler(Model model) {
List<String[]> msglist = new ArrayList<String[]>();
String[] arr = new String[] {"aa", "bb", "cc"};
msglist.add(arr);
arr = new String[] {"good", "hello"};
msglist.add(arr);
arr = new String[] {"abc@sohu.com", "xyz@sina.com"};
msglist.add(arr);
model.addAttribute("msglist", msglist);
return "user";
}
```
在上面的代码中,我们使用 `ArrayList` 来存储数组列表,并将其添加到 Model 中。在视图层中,我们可以使用 Thymeleaf 的 `th:each` 属性来遍历数组列表。
在视图层中的代码如下所示:
```html
<table id="msglistTable" style="position:absolute;left:-58000px;top:0px;">
<tr th:each="items: ${msglist}">
<td th:each="item: ${items}" th:text="${item}"></td>
</tr>
</table>
```
在上面的代码中,我们使用 `th:each` 属性来遍历数组列表,并使用 `th:text` 属性来显示数组元素的值。
在 JS 中,我们可以使用 `document.getElementById` 方法来获取表格元素,并使用 `for` 循环来遍历数组列表。代码如下所示:
```javascript
var msglist = [];
$(document).ready(init);
function init() {
try {
var tb = document.getElementById("msglistTable");
for (var r = 0; r < tb.rows.length; r++) {
var arr = [];
var row = tb.rows[r];
for (var c = 0; c < row.cells.length; c++) {
arr[c] = row.cells[c].innerText;
}
contentCfgs[r] = arr;
}
} catch (e) {
alert("e=" + e);
}
}
```
在上面的代码中,我们使用 `document.getElementById` 方法来获取表格元素,并使用 `for` 循环来遍历数组列表。我们还使用 `try-catch` 语句来捕获异常。
在 Thymeleaf 网页中获取 Model 中的数组列表可以使用 Thymeleaf 的 `th:each` 属性和 JS 的 `for` 循环来实现。通过这种方式,我们可以轻松地获取后台传递过来的数组列表,并在前台进行处理和显示。
264 浏览量
2463 浏览量
249 浏览量
111 浏览量
277 浏览量
点击了解资源详情

rbc168
- 粉丝: 1
最新资源
- iBatis 2.0 开发指南:快速上手与高级特性
- Linux USB内核学习笔记
- J2EE电商系统入门精通:Struts+Hibernate实战教程
- JUnit测试框架:简化Java开发的利器
- 使用Struts2构建Web 2.0项目的实战指南
- 软件开发笔试试题解析与解答
- SWT图形用户界面教程:Java GUI开发
- 华为面试题解析:JAVA面试焦点
- Cisco路由器密码恢复步骤详解
- 面向对象分析与设计实战指南
- Quest Software's TOAD for Oracle 演示与介绍
- 《Struts in Action》中文版详解:Java Web框架深度解析
- 软件工程模式与项目管理探讨
- UML设计与软件工程实践:案例分析与工具详解
- 面向对象技术与UML方法:软件工程访谈与实践
- Core J2EE模式:最佳实践与设计策略