应用程序抛出org.springframework.expression.spec.SpelEvaluationException:EL1007E:(位置0):在null 上找不到属性或字段"title"
我不明白为什么。。。这是由master调用的html片段。
<title th:fragment="title">Surveys Feed</title>
<div th:fragment="content" th:each="surv : ${allSurveys}" >
<div id="surv-ct" style="min-width: 310px; max-width: 800px; height:400px; margin: 0 auto">
<script th:inline="javascript">
/*<![CDATA[*/
$('#surv-ct').highcharts({
chart: {
type: 'bar'
},
title: {
text: [[${surv.title}]]
},
// ... other stuff
</script>
</div>
</div>
然而,当应用程序启动时,字段标题不为空!这里我们有对象allSurveys的映射,它从repo中获取所有调查并返回一个列表。
@ModelAttribute("allSurveys")
public List<Survey> allSurveys() {
List<Survey> surveys = new Surveys(repo.findAll()).getSurveys();
// print surveys titles
for (int i = 0; i < surveys.size(); i++) {
Survey sur = surveys.get(i);
System.out.println("Survey info: " + sur.getTitle());
}
return surveys;
}
作为证据,我们可以看到调查的标题打印在控制台上:控制台输出
并且它们在数据库中呈现调查数据库
那么,为什么它说这是无效的呢?我在网上看到了不同的答案,但似乎没有一个能解决我的问题。
提前感谢您的帮助。
编辑:根据建议,我尝试打印对象${surv}。我将内部div的"surv ct"属性从ID改为class,因为它们应该是多个。
<div th:fragment="content" th:each="surv : ${allSurveys}" >
<div class="surv-ct" style="min-width: 310px; max-width: 800px; height: 400px; margin: 0 auto">
<p>Object is: <span th:text=${surv}>obj</span></p>
<!--
<script th:inline="javascript">
/*<![CDATA[*/
$('.surv-ct').highcharts({
chart: {
type: 'bar'
},
// ... more code
-->
</div>
</div>
当我在Mozilla上分析代码时,这就是结果。
<p>Object is: <span></span></p>
<!--
<script th:inline="javascript">
/*<![CDATA[*/
$('.surv-ct').highcharts({
// ... more code that i deleted
// it's commented anyway
-->
首先,只打印一个结果。其次,它没有得到任何监视对象。这就是为什么字段"title"为空的原因。那么,为什么对象为null呢?有什么建议吗?
我怀疑这是因为在使用片段时使用了th:include
。根据Thymelaf文件:
th:include会将片段的内容包含到其宿主标签中,而th:replace实际上会用片段的替换宿主标签
这意味着你的th:each
将被忽略——这解释了为什么你只看到打印的一个结果。
解决方案是使用th:replace
,它将使用th:if
。或者,您可以稍微更改片段的格式,使th:each
成为片段内容的一部分。例如:
<th:block th:fragment="content">
<div th:each="surv : ${allSurveys}">
<div id="surv-ct" style="min-width: 310px; max-width: 800px; height:400px; margin: 0 auto">
<script th:inline="javascript">
/*<![CDATA[*/
$('#surv-ct').highcharts({
chart: {
type: 'bar'
},
title: {
text: [[${surv.title}]]
},
// ... other stuff
</script>
</div>
</div>
</th:block>