zkgrails - LoadOnDemand

 

  LoadOnDemand  
A tutorial to load data on-demand.

This is a ZKGrails port of the program written in http://docs.zkoss.org/wiki/Use_Load-On-Demand_to_Handle_Huge_Data. This tutorial is working for ZKGrails 0.7.1 and later.

You need to prepare a Grails project for this tutorial by type:

grails create-app ondemand

Next, you need to install ZKGrails. The latest version will be installed automatically, when type:

grails install-plugin zk

We are going to demonstrate with a simple domain class, Employee. To create domain class in Grails, simply use the command create-domain-class, following by your class name:

grails create-domain-class employee

We then add two properties into domain class Employee, namely fullname and username. Both are string.

class Employee {

   
String fullname
   
String username

   
static constraints = {
   
}
}

grails create-zul employee

This will also create grails-apps/composers/EmployeeComposer.groovy for you.

<window apply="${employeeComposer}">

   
<vbox>
       
<image src="images/grails_logo.jpg"/>
   
</vbox>

   
<listbox id="lstEmployee" width="100%" checkmark="true">
       
<listhead sizable="true">
           
<listheader label="ID" sort="auto" />
           
<listheader label="Full Name" sort="auto" />
           
<listheader label="User Name" sort="auto" />
       
</listhead>
 
</listbox>
 
<paging id="pagEmployee" pageSize="30" />

</window>

From the code, you may see 2 properties lstEmployee, and pagEmployee. Both are injected by GrailsComposer, which is a subclass ofGenericForwardComposer. They, apparently, represents listbox and paging components from your .zul file.

You may notice that there is afterCompose closure. This closure is run by doAfterCompose, and it's a Groovy place to initialize your components.

The auto-wired event handle onPaging_pagEmployee will be called everytime you click pagEmployee to change the active page. Note that, the only argument of the handler must be ForwardEvent or Event to make it work.

I also show you the use of Groovy's default argument value declared at redraw method. That is, calling redraw() in afterCompose meansredraw(0).

Also in redraw method, there are two places to use dynamic methods added by ZKGrails. The first one is listbox#clear, of which removes all listitem. The second one is append, which accepts component construction via ZK Builder.

import org.zkoss.zkgrails.*
import org.zkoss.zk.ui.event.*

class EmployeeComposer extends GrailsComposer {

   
def lstEmployee
   
def pagEmployee

   
def afterCompose = { c ->
        pagEmployee
.totalSize = Employee.count()
        redraw
()
   
}

   
def onPaging_pagEmployee(ForwardEvent fe) {
       
def e = fe.origin
        redraw
(e.activePage)
   
}

   
def redraw(page=0) {
       
def list = Employee.list(offset: page * pagEmployee.pageSize,
                                 max
: pagEmployee.pageSize)

        lstEmployee
.clear()
        lstEmployee
.append {
            list
.each { e ->
                listitem
(value: e) {
                    listcell
(label: e.id)
                    listcell
(label: e.fullname)
                    listcell
(label: e.username)
               
}
           
}
       
}
   
}

}

Before getting your application run, you need some testing data to show. Open grails-app/conf/BootStrap.groovy, and then add the following snippet into init closure.

     def init = { servletContext ->
       
1000.times { i ->
           
new Employee(fullname: "Name $i", username: "user$i").save()
       
}
     
}

With the above code, we loop 1,000 times to create 1,000 domain objects of class Employee.

grails run-app

and point your browser to http://localhost:8080/ondemand/employee.zul

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值