渲染视图后对象列表消失
a List of objects disappeared after Rendering a view
尊敬的 grails 专家
我正在向我的 gsp 查看页面发送一份出版物列表。我可以很好地看到该列表,但是在将其中一个出版物添加到书籍列表并呈现出版物 gsp 视图页面之后,出版物列表不再被视为出版物列表,而是被视为一个字符串。因此,当我尝试获取每份出版物时,它都会给我字符。
我使用的是grails 2.2.0版本。
我在这里发送控制器条目中的出版物:
def books{
def unit = Unit.get(params.id)
def period = Period.get(params.periodId)
def publications = []
if (unit) {
def units = unit.downHierarchy().id
units.removeAll { null }
publications = Publication.publicationsOfUnits(units)?.listDistinct()?.findAll{it.date.getAt(Calendar.YEAR) == period.year}?.sort{ it.date }
}
[publications : publications, id: unit.id, unitId: unit.id, periodId: period.id]
}
这是我的查看页面:
<table>
<g:each in="${publications}" var="p">
<g:if test="${p instanceof publicationBook}">
<tr>
<td>${p.authors.join(",")}</td>
<td>${p.title}</td>
<td>
<a href="#" onclick="$('#author').val('${p.authors.join(',')}');$('#titleAndSubtitle').val('${p.title}');$('#unitId').val('${unitId}');$('#periodId').val('${periodId}');$('#id').val('${unitId}');bookForm.submit();">Add to Books</a>
</td>
</tr>
</g:if>
</g:each>
</g:table>
这里我将出版物添加到书籍中:
def saveBook = {
saveEntry("book", new Book())
render(view:"books", model: params)
}
这里是我将出版物列表再次发送给控制器以进行呈现的书籍表单:
<g:form name="bookForm" controller="entries" action="saveBook" class="default" method="post">
<g:hiddenField name="entryId" value="${entry?.id}"/>
<g:hiddenField name="unitId" value="${unitId}"/>
<g:hiddenField name="periodId" value="${periodId}"/>
<g:hiddenField name="publications" value="${publications}"/>
<div class="buttons">
<button class="button icon icon_arrow_right leave_empty" onclick="$('#leaveEmpty').val('true');bookForm.submit();"
</div>
</g:form>
如果有任何建议或帮助解决问题,我将不胜感激..
您没有在此处传递正确的模型 render(view:"books", model: params)
。
要么使用 redirect(action:"books", id: id)
,要么使用 publications
列表等填充模型,就像您在 books
操作中所做的那样
尊敬的 grails 专家
我正在向我的 gsp 查看页面发送一份出版物列表。我可以很好地看到该列表,但是在将其中一个出版物添加到书籍列表并呈现出版物 gsp 视图页面之后,出版物列表不再被视为出版物列表,而是被视为一个字符串。因此,当我尝试获取每份出版物时,它都会给我字符。
我使用的是grails 2.2.0版本。
我在这里发送控制器条目中的出版物:
def books{
def unit = Unit.get(params.id)
def period = Period.get(params.periodId)
def publications = []
if (unit) {
def units = unit.downHierarchy().id
units.removeAll { null }
publications = Publication.publicationsOfUnits(units)?.listDistinct()?.findAll{it.date.getAt(Calendar.YEAR) == period.year}?.sort{ it.date }
}
[publications : publications, id: unit.id, unitId: unit.id, periodId: period.id]
}
这是我的查看页面:
<table>
<g:each in="${publications}" var="p">
<g:if test="${p instanceof publicationBook}">
<tr>
<td>${p.authors.join(",")}</td>
<td>${p.title}</td>
<td>
<a href="#" onclick="$('#author').val('${p.authors.join(',')}');$('#titleAndSubtitle').val('${p.title}');$('#unitId').val('${unitId}');$('#periodId').val('${periodId}');$('#id').val('${unitId}');bookForm.submit();">Add to Books</a>
</td>
</tr>
</g:if>
</g:each>
</g:table>
这里我将出版物添加到书籍中:
def saveBook = {
saveEntry("book", new Book())
render(view:"books", model: params)
}
这里是我将出版物列表再次发送给控制器以进行呈现的书籍表单:
<g:form name="bookForm" controller="entries" action="saveBook" class="default" method="post">
<g:hiddenField name="entryId" value="${entry?.id}"/>
<g:hiddenField name="unitId" value="${unitId}"/>
<g:hiddenField name="periodId" value="${periodId}"/>
<g:hiddenField name="publications" value="${publications}"/>
<div class="buttons">
<button class="button icon icon_arrow_right leave_empty" onclick="$('#leaveEmpty').val('true');bookForm.submit();"
</div>
</g:form>
如果有任何建议或帮助解决问题,我将不胜感激..
您没有在此处传递正确的模型 render(view:"books", model: params)
。
要么使用 redirect(action:"books", id: id)
,要么使用 publications
列表等填充模型,就像您在 books
操作中所做的那样