- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用 Thymeleaf 3 layouts 向片段添加额外的内容,但无法弄清楚如何去做。例如,我想要一个名为 layout
的片段,如下所示:
<head th:fragment="head(title)">
<title th:include="${title}">My App: </title>
</head>
然后有一个使用上面片段的模板:
<head th:include="layout :: head(title=~{::title})">
<title>Please Login</title>
</head>
内容呈现如下:
<head>
<title>Please Login</title>
</head>
但是,我想修改模板,使其呈现如下所示,并将 My App:
放在 layout
模板中(我不想让复制它)。
<head>
<title>My App: Please Login</title>
</head>
我可以使用以下方法让它工作:
<head th:fragment="head(title)">
<title th:include="${title}">My App: <th:block th:include="${title}"></th:block></title>
</head>
但是,Thymeleaf 不鼓励使用 th:include
。 From the reference :
And what is the difference between th:insert and th:replace (and th:include, not recommended since 3.0)?
谁能告诉我如何使用最佳实践修复我的模板,使其呈现如上所示(如前所述,引用暗示这意味着不使用 th:include
)?
最佳答案
这里的复杂性来自于你不想要你的 <title>
标记直接进入您的片段(使用 ~{::title}
和片段的 th:replace
标记处的 <title>
很容易)。相反,正如您所解释的那样,您实际上是在丰富您片段的 <title>
包含来自包含模板的文本内容。
这里的关键是使用 /text()
标记选择器中的修饰符,表示“选择此标记的文本内容”,例如:
<head th:include="layout :: head(title=~{::title/text()})">
<title>Please Login</title>
</head>
(有关标记选择器语法的完整引用,请参阅 http://www.attoparser.org/apidocs/attoparser/2.0.0.RELEASE/org/attoparser/select/package-summary.html)
这将使您的 title
变量包含 Fragment
由单个节点/事件组成的对象,一个 IText
包含文本 "Please Login"
.
如您所说,th:include
现在不鼓励(在 3.1 中弃用),取而代之的是 th:insert
和 th:replace
是首选。原因是th:include
的机制似乎不是完全直接的,并且通常会引起误解(基本上,很多人认为它做了现在 th:insert
做的事情,这要简单得多)。此外,th:include
添加了一些不需要的计算复杂性。
th:replace
与 2.1 中的完全相同,即实际上用片段替换主机标记。 th:insert
会将片段插入到主机标记的正文中。一组更简单的选项,恕我直言。
回到您的代码,因此我会将其发展为使用 th:replace
:
<head th:replace="layout :: head(title=~{::title/text()})">
<title>Please Login</title>
</head>
至于你的片段,在你的情况下我会选择内联,这可能是这里最简单的选择:
<head th:fragment="head(title)">
<title>My App: [[${title}]]</title>
</head>
请注意,在本例中我们使用的是 Fragment
(即 片段表达式 的结果,在本例中为 ~{::title/text()}
),我们只是通过 内联 (相当于 th:text
)输出它,就好像而不是一个片段 title
变量仅包含 String
.但这是 v3.0 中新片段表达式的灵 active 的一部分。
如果你不喜欢内联,你可以选择类似的东西:
<head th:fragment="head(title)">
<title th:text="|My App: ${title}|">My App</title>
</head>
如果有可能 including 模板没有<title>
标签,你想检查这种可能性,只需使用 My App
文本作为标题如果没有标题被发送到片段,你可以使用新的 no-op 标记(_
):
<head th:fragment="head(title)">
<title th:text="${title} ? |My App: ${title}| : _">My App</title>
</head>
免责声明,根据 StackOverflow 规则:我是 Thymeleaf 的项目负责人。
关于java - 如何在 Thymeleaf 3 中向片段添加其他内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40031739/
问题:如何对文本文字中的多个连续下划线进行转义? 我正在为 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
我是一名优秀的程序员,十分优秀!