我想为我的表添加一个数据过滤器。有人可以帮助我吗?我已经为列表控制器编写了代码,但我不知道如何在我的 .gsp 文件中实现“mitarbeiterSelectedId”。
目前我有以下代码片段。
这是我的控制器“列表”
def list(Integer max) {
def mitarbeiterList = Mitarbeiter.listOrderByNachname()
if (params.selectedMitarbeiterId != null && params.selectedMitarbeiterId != '-1'){
mitarbeiterList = [Mitarbeiter.findById(params.selectedMitarbeiterId)]
}
[mitarbeiterInstanceList: mitarbeiterList, mitarbeiterInstanceTotal: Mitarbeiter.count() ]
}
这是我的 list.gsp
<g:select id="mitarbeiter" name="mitarbeiterId" from="${Mitarbeiter.list()}" optionValue="nachname"
optionKey="id"
noSelection="${['-1': 'Bitte auswählen...']}" onchange="selectedMitarbeiterId"/>
<g:actionSubmit value="submit" onclick="" >OK</g:actionSubmit>
<table>
<thead>
<tr>
<g:sortableColumn property="nachname" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiter.nachname.label', default: 'Nachname')}"/>
<g:sortableColumn property="vorname" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiter.vorname.label', default: 'Vorname')}"/>
<g:sortableColumn property="sollpensum" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiterHistory.sollpensum.label', default: 'Sollpensum')}"/>
<sec:ifAllGranted roles="ROLE_ADMIN">
<g:sortableColumn property="gehalt" params="[controller: 'mitarbeiter']"
title="${message(code: 'mitarbeiterHistory.gehalt.label', default: 'Gehalt')}"/>
</sec:ifAllGranted>
<th><g:message code="mitarbeiterHistory.bereich.label" default="Bereich"/></th>
</tr>
</thead>
<tbody>
<g:each in="${Mitarbeiter.list()}" status="i" var="mitarbeiterInstance">
<tr class="${(i % 2) == 0 ? 'even' : 'odd'}">
<td><g:link action="show" controller="mitarbeiter"
id="${mitarbeiterInstance.id}">${fieldValue(bean: mitarbeiterInstance, field: "nachname")}</g:link></td>
<td>${fieldValue(bean: mitarbeiterInstance, field: "vorname")}</td>
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "sollpensum")}</td>
<sec:ifAllGranted roles="ROLE_ADMIN">
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "gehalt")}</td>
</sec:ifAllGranted>
<td>${fieldValue(bean: mitarbeiterInstance.histories, field: "bereich")}</td>
</tr>
</g:each>
</tbody>
</table>
有人可以帮我解决这个问题吗?
编辑 :
好的,目前我的班级看起来像这样。
class Employee{
String firstname
String lastname
static hasMany = [histories:EmployeeHistory]
static constraints = {
firstname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
lastname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
}
}
所以当我插入你的代码时,它看起来像这样:
class Employee{
String firstname
String lastname
static hasMany = [histories:EmployeeHistory]
static constraints = {
firstname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
lastname nullable: false, blank: false, minSize: 2, matches: "[a-zA-ZäöüÄÖÜßéèáàúùóò'\\- ]+"
}
static namedQueries = {
filteronLastname { String inLastname ->
if (inLastname && inLastname?.size() > 0) {
ilike 'lastname', "%${inLastname}%"
}
}
}
}
如果在下拉列表中未选择任何内容,我想显示整个表格数据。
如果我在下拉列表中选择一名员工,我只想显示包含所选员工数据的表格。
目前这是我的员工名单控制器
def list() {
params.max = Math.min(params.max ? params.int('max') : 10, 100)
def employeeList = Employee.filteronLastname(params?.lastName).list(params)
[employeeInstanceList: employeeList, employeeInstanceTotal: employeeList.totalCount ]
}
我必须在哪里插入这个:
NewsItem.filterLastname(params?.Lastname).
list()
以及我必须如何改变<g:selected>
?