Grails使用下拉列表过滤数据

时间:2013-04-11 06:45:44

标签: grails filter

我想为我的表添加数据过滤器。有人能帮助我吗? 我已经为列表控制器编写了代码,但我没有 知道如何在我的.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>

1 个答案:

答案 0 :(得分:0)

为了过滤数据,我们最近采用了另一种方法。为了实现灵活的过滤可能性,我们使用namedqueries实现了过滤方法。

一个带有一些随机代码的小例子,解释了这个想法!:

class NewsItem {
    String title
    String message

    static namedQueries = {
        filteronTitleILike { String inTitle ->
            if (inTitle && inTitle?.size() > 0) {
                ilike 'title', "%${inTitle}%"
            }
        }

        filteronMessageILike { String inMessage ->
            if (inMessage && inMessage ?.size() > 0) {
                ilike 'message', "%${inMessage }%"
            }
        }
    }
}

要使用过滤,我们现在可以执行以下操作:

NewsItem.filterOnTitleILike(params?.title).
filterOnMessageILike(params?.message).
list()

使用此方法的一个主要优点是,当数据从gsp发送到控制器时,我们非常灵活。如果params?.title没有填充aka null,那么在namedquery中不考虑这个。因此,我们只提供参数?。消息它保持完美!