- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试遍历对象列表并生成 div class="card-deck"
每4
对象和嵌套 div class="card"
对于每个对象。
这是在 上生成异常的代码第 234 行
更新:注:第 234 行 在 html
中提到并拥有 <!-- Error-Line 234 -->
由于缺少 )
在 ${#numbers.sequence(0,3}
<div class="card-deck" th:each="qr: ${objects}" th:if="${qr.tableid}%4==0"> <!-- Iterate every 4 objects -->
<!--syntax error missed clossing ) at ${#numbers.sequence(0,3) triggered the exception here -->
<div class="card" th:each="i : ${#numbers.sequence(0,3)} "> <!-- Error-Line 234 -->
<!-- Some More Code -->
<img th:src="${qr.qrcodestaticpath}" class="card-img-top" alt="...">
<div class="card-body">
<h5 class="card-title" align="center" th:text="'Table '+${qr.tableid}"></h5>
<p class="card-text" align="center" th:text="'Random Generated QR Code'"></p>
<h6 align="center" th:text=" ${qr.qrcodestring}"></h6>
</div>
</div>
</div>
org.thymeleaf.exceptions.TemplateInputException: An error happened during template parsing (template: "class path resource [templates/qrcodes.html]" - line 234, col 10)
exception
<div class="card-deck" ...
每 4 或 5 table 。由于
<div class="card" th:each="i : ${#numbers.sequence(0,3)} ">
我得到了 4 张相同的 table 。
qr.tableid
是表号,1 到 x java
片段
int numOfObjects=11;
for(int i=0 ;i<numOfObjects;i++)
{
if(i%4==0)
{
System.out.println();
System.out.print("Deck:");
}
System.out.print("Card"+(i+1)+" ");
}
Controller
@GetMapping("/qrcodes")
public String greetingForm(Model model) {
List<QrObject> qr =qrRepo.findAll();
int numOfobj= qr.size();
int decks;
if(numOfobj % 4==0)
decks = numOfobj / 4 ;
else
decks = (numOfobj / 4) +1 ;
int posa_periseuoun = numOfobj % 4 ;
model.addAttribute("objects", qr);
model.addAttribute("decks",decks);
model.addAttribute("cards",posa_periseuoun);
model.addAttribute("size", numOfobj);
return "qrcodes";
}
最佳答案
这是一种我认为代表您正在尝试做的方法。
最终结果
跳转到最终结果,这将在浏览器中显示以下文本:
Deck: Card1 Card2 Card3 Card4
Deck: Card5 Card6 Card7 Card8
Deck: Card9 Card10 Card11
<div class="card-deck">
<span>Deck: </span>
<span class="card">Card1 </span>
<span class="card">Card2 </span>
<span class="card">Card3 </span>
<span class="card">Card4 </span>
</div>
<div class="card-deck">
<span>Deck: </span>
<span class="card">Card5 </span>
<span class="card">Card6 </span>
<span class="card">Card7 </span>
<span class="card">Card8 </span>
</div>
<div class="card-deck">
<span>Deck: </span>
<span class="card">Card9 </span>
<span class="card">Card10 </span>
<span class="card">Card11 </span>
</div>
public class Deck {
private final String deckName;
private final List<Card> cards = new ArrayList();
public Deck(String deckName) {
this.deckName = deckName;
}
public List<Card> getCards() {
return cards;
}
public String getDeckName() {
return deckName;
}
}
public class Card {
private final String cardName;
public Card(String cardName) {
this.cardName = cardName;
}
public String getCardName() {
return cardName;
}
}
Map<String, Object> model = new HashMap();
// this is equivalent to your findAll()...
List<Card> allCards = new ArrayList();
for (int i = 1; i<= 11; i++) {
allCards.add(new Card("Card" + i));
}
int maxCardsPerDeck = 4;
List<Deck> decks = new ArrayList();
Deck deck;
List<Card> deckCards = new ArrayList();
int cardCount = 0;
for (Card card : allCards) {
cardCount++;
deckCards.add(card);
if (cardCount % maxCardsPerDeck == 0 ||
cardCount == allCards.size()) {
deck = new Deck("Deck");
deck.getCards().addAll(deckCards);
decks.add(deck);
deckCards.clear();
}
}
model.put("decks", decks);
<div class="card-deck"
th:each="deck: ${decks}">
<span th:text="${deck.deckName + ': '}">
</span>
<span class="card"
th:each="card: ${deck.cards}"
th:text="${card.cardName + ' '}">
</span>
</div>
<span>
s 在这里,只是为了让事情保持一致。你可以使用任何你需要的东西,并提供你需要的 CSS 样式。
关于java - Thyemleaf 嵌套迭代触发 org.thymeleaf.exceptions.TemplateInputException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61111220/
问题:如何对文本文字中的多个连续下划线进行转义? 我正在为 HTML 使用标准的 Thymeleaf 方言(我不在这里使用 Spring 或 SpEL)。 在 Thymeleaf 中,我可以将下划线创
在 SaaS 应用程序中,我使用了一些模板来生成通知电子邮件或某些 HTML 页面。到目前为止,我没有使用 thymeleaf,而且所有模板都是硬编码的,但我很想改变它,以便应用程序的用户可以自己编辑
我看到JSP页面有.jsp/.jspf/.jspx后缀(来自 JavaServer Pages™ Specification Version2.2),Velocity 模板使用 .vm后缀,FreeM
我有一个像这样的 Thymeleaf 片段 ... 脚本部分我只想包含它一次,即使我会在页面中多次包含 f1 。实现这一目标最简单/最干净的方法是什么? 我什至可以将此片段拆
两个 Thymeleaf 属性有什么区别:th:include 和 th:replace? 最佳答案 根据documentation如果您遇到这种情况: content here 片段将被放置在
我是 Thymeleaf 初学者。我从一个通用布局页面开始: fragments/layout.html Template title Some text
我有两个数组,我想在同一个表(不同的列)中显示其内容。如何使用 index 或 th:each 遍历数组 这是我想要实现的目标 List1Elm1 List
我在 session 中有一个对象,例如一个部门,这个部门有 child 。我得到了它的 child 的列表,现在我想在这个列表中添加这个部门对象。这在服务器端非常简单,但可以做到这个在 thymel
我的 Thymeleaf 页面中有几个下拉列表,如下所示: 当我查看页面时,列表中的第一个值显示为已选中,并且实际上已作为选中值提交,即使它不是手动选中的。我宁愿默认不选择任
我有一个通用的布局,默认情况下,除已包含(更高级的)搜索表单的搜索页面本身之外,每个页面上均应显示(基本)搜索表单。 是否可以将参数从我的搜索页面传递到版式,以便不显示默认搜索表单? 这是我想做的一个
我有一个 User 对象列表,我想将它转换为一个名称列表,加入它并呈现它(不是在表格中)。我该怎么做? class User { String name; String address; }
我在前端使用thymeleaf,我知道variable中的thymeleaf概念 如果我使用th:text,变量中的值将被打印,并且我可以在同一元素中使用该变量。有没有办法在其他元素中使用var呢?
我知道 Thymeleaf 是为渲染 View 而制作的,但是我只是想知道是否有任何方法可以在 Thymeleaf 片段的请求范围内设置变量? 我有一个非常大的条件表达式,我必须在整个应用程序中重复很
假设我有两个 Thymeleaf 模板: index.html : foo bar 片段/main.html : This is the main cont
我想声明一些布局用作所有表单字段的模板。 大致给出这个片段 Edition description 这个片段“调用” 它将产生
在 Thymeleaf 中实现 Markdown 的最佳方式是什么? 模板模式 一种新的方言(什么处理器?) 如果我可以在 HTML 中嵌入 markdown,那将会很有用。 最佳答案 根据我对 Ja
我想使用模板片段创建最多包含三个项目的列表。无论是否有项目,项目都会显示三个空格,因此看起来像这样。 0}" th:insert="code-block :: block(${bloc
如何从 Thymeleaf 重定向页面(我有如下 JSP 代码) out.println("REDIRECT=http://www.example.com/api/response?id="+id)
我想在 Thymeleaf 的字符串中放置双引号,我有以下形式: 我想要的结果是: Value of "apple" is "1.5". 但我得到以下异常: EL1065E: unexpected
我想使用模板片段创建最多包含三个项目的列表。无论是否有项目,项目都会显示三个空格,因此看起来像这样。 0}" th:insert="code-block :: block(${bloc
我是一名优秀的程序员,十分优秀!