6

我想在我的 grails 应用程序中添加一些分页内容。我有列表操作,并在其中执行了此操作:

if(!params.max){
params.max = 3
}
    def query = Profile.where {
        userType == "F"
    }
    def freelancers = query.list(sort:"firstName", max:params.max)
    if(freelancers) {
        def freelancersCount = query.count()
        return[freelancer:freelancers, fCount:freelancersCount]
    } else {
        response.sendError(404)
    }

在 gsp 中我写了这个:

<div id="paginate">
    <g:paginate controller="freelancers" action="list" total="${fCount}"/>
</div>

一切正常,我的数据库中有 5 个对象,在浏览器中打开 gsp 页面时我只能看到 3 个,但是当我单击下一步打开其他 2 个对象时,我看到了相同的 3 个。出了什么问题,我必须做什么?

4

2 回答 2

8

您需要将偏移量传递到对list的调用中:

def freelancers = query.list(sort:"firstName", offset:params.offset, 
max:params.max)
于 2012-07-16T15:12:02.537 回答
1

1)如果您使用的是标准查询,那么:

 params.max = Math.min(max ?: 10, 100)
 Integer offset = params.offset as Integer ?: 0
 List userInstanceList = User.createCriteria().list(max:params.max,offset:offset) {
            or {
                ilike('name', "%${name}%")
                ilike('email', "%${email}%")
            }
            order('dateCreated', 'desc')
        }

2)如果您使用的是 GORM 查询,那么:

 params.max = Math.min(max ?: 10, 100)
 Integer offset = params.offset as Integer ?: 0
 List<User> userList=User.list(max:params.max,offset:offset)
于 2014-09-04T10:54:09.767 回答