Suggested case list:
Using timer to refresh a grid
383guest172.69.33.12125nk0uiMay 7, 2020 7:23:47 AMlinkuser model to move item to another listbox
120guest162.158.193.148d0n3krApr 2, 2020 5:28:28 AMlinkDisabled list item row passed to VM-1981
296fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:44 PMlinkDisabled list item row passed to VM-1981
295fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:16 PMlinkDisabled list item row passed to VM-1981
294fatih123160.83.36.13225nk0uiFeb 13, 2018 3:30:44 PMlinkgrid sample with ListModel/RowRenderer
816guest80.82.2.1312vah9ajFeb 21, 2017 11:42:21 AMlinkgrid sample with ListModel/RowRenderer
809guest175.98.113.1622vah9ajJan 26, 2017 9:19:33 AMlinkgrid sample with ListModel/RowRenderer
196guest79.185.142.402vah9ajApr 26, 2014 10:53:57 PMlinkgrid sample with ListModel/RowRenderer
195guest79.185.142.402vah9ajApr 26, 2014 10:53:54 PMlinkgrid sample with ListModel/RowRenderer
194guest79.185.142.402vah9ajApr 26, 2014 10:53:51 PMlinkgrid sample with ListModel/RowRenderer
193guest79.185.142.402vah9ajApr 26, 2014 10:53:48 PMlinkgrid sample with ListModel/RowRenderer
192guest79.185.142.402vah9ajApr 26, 2014 10:53:44 PMlinkgrid sample with ListModel/RowRenderer
191guest79.185.142.402vah9ajApr 26, 2014 10:53:40 PMlinkHierarchy table without using ZK PE/EE
1aaknai151.28.135.2131s871daJul 29, 2013 11:02:46 PMlinkgrid sample with ListModel/RowRenderer
128aaknai151.28.135.2132vah9ajJul 29, 2013 7:20:00 PMlinkuser model to move item to another listbox
1TonyQ114.25.109.94d0n3krApr 21, 2012 10:43:27 AMlinkUsing timer to refresh a grid
1TonyQ220.133.44.3725nk0uiFeb 17, 2012 3:17:34 AMlinkFire a event from child iframe
1TonyQ220.133.44.372eupjotFeb 3, 2012 5:04:52 AMlinkTextbox input restriction sample
1TonyQ72.21.245.2431b3nlr0Dec 20, 2011 10:09:10 AMlinkTest web core taglib in ZUL
1TonyQ198.203.175.175ofqkemDec 17, 2011 3:36:08 AMlinkLatest 10 Fiddles :
constraint binding textbox
3guest172.68.151.16220peldaDec 5, 2025 5:08:19 PMlinkAnother new ZK fiddle
2guest172.68.151.16320peldaDec 5, 2025 5:07:51 PMlinkAnother new ZK fiddle
1guest172.68.151.16220peldaDec 5, 2025 5:07:32 PMlinkAnother new ZK fiddle
1peggypeng172.71.154.99364f4neDec 5, 2025 9:24:31 AMlinktooltip example
2guest104.22.23.13rc1ntoDec 4, 2025 2:23:45 PMlinkAnother new ZK fiddle
1guest172.69.134.2277t7602Dec 4, 2025 1:40:46 PMlinkAnother new ZK fiddle
1peggypeng104.22.17.1802df6e3oDec 4, 2025 8:41:29 AMlinkonClose
1peggypeng172.68.87.248j8kd8aDec 3, 2025 4:10:26 AMlinkAnother new ZK fiddle
1peggypeng172.69.134.2271rm7f4eNov 26, 2025 3:31:24 AMlinkZK-5912-Suggestion
2rebeccalai104.22.20.1442qrmiiuNov 26, 2025 2:07:15 AMlinkAnother new ZK fiddle
2guest114.249.149.41b6p3ciAug 20, 2014 5:18:04 AMlinkresources
index.zulzul<vlayout vflex="1" hflex="1" id="contentsDemo" class="page-content" apply="com.dbs.ux.bind.BindComposer" viewModel="@id('vm') @init('com.smartdot.icm.module.demo.vm.DemoListVM')">
<!--
<include src="content/alert.ul"/>
-->
<hlayout>
<div hflex="1">
<button sclass="btn btn-primary pull-right" onClick="@command('new')">新建</button>
</div>
</hlayout>
<separator/>
<panel border="none" sclass="transparent">
<panelchildren style="padding-top:10px;">
<div class="form-horizontal">
<div class="form-body">
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label col-md-3" value="流程名称"/>
<div class="col-md-9">
<textbox value="@bind(vm.processName)"/>
</div>
</div>
</div>
<div class="col-md-6">
<div class="form-group">
<label class="control-label col-md-3" value="流程编号"/>
<div class="col-md-9">
<textbox value="@bind(vm.processCode)"/>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-6">
<div class="form-group">
<label class="control-label col-md-3" value="级别"/>
<div class="col-md-9">
<textbox value="@bind(vm.level)"/>
</div>
</div>
</div>
<div class="col-md-6">
<button type="button" class="btn btn-primary pull-right" iconSclass="z-icon-search" onClick="@command('search')">查询</button>
</div>
</div>
</div>
</div>
</panelchildren>
</panel>
<grid id="listGrid" sclass="uxtable" mold="paging" pageSize="10" vflex="1" width="100%"
emptyMessage="没找到相关数据." model="@load(vm.dataList)">
<columns>
<column label="序号" width="50px"/>
<column label="流程名称" />
<column width="100px" label="流程编号" />
<column width="80px" label="级别" />
<column width="100px" label="版本" />
<column width="100px" label="创建人" />
<column width="140px" label="创建时间" />
<column width="100px" label="操作" />
</columns>
<rows>
<template name="model" var="data">
<row sclass="task-orange" self="@{each='data'}">
<label value="@load(data.processName)"/>
<label value="@load(data.processName)"/>
<label value="@load(data.processCode)"/>
<label value="@load(data.level)"/>
<label value="@load(data.versionId)"/>
<label value="@load(data.creatorName)"/>
<label value="@load(data.createTime)@converter('formatedDate',format='yyyy-MM-dd HH:mm:ss')"/>
<div style="padding-top:0px">
<a iconSclass="z-icon-search green" onClick="@command('view',entity=data)" />
<a iconSclass="z-icon-pencil blue" onClick="@command('edit',entity=data)" />
<a iconSclass="z-icon-trash-o red" onClick="@command('delete',entity=data)"/>
</div>
</row>
</template>
</rows>
</grid>
</vlayout>
TestComposer.javajavapackage com.smartdot.icm.module.demo.vm;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.dbs.ux.bind.Binder;
import com.dbs.ux.bind.annotation.AfterCompose;
import com.dbs.ux.bind.annotation.BindingParam;
import com.dbs.ux.bind.annotation.Command;
import com.dbs.ux.bind.annotation.ContextParam;
import com.dbs.ux.bind.annotation.ContextType;
import com.dbs.ux.bind.annotation.Init;
import com.dbs.ux.bind.annotation.NotifyChange;
import com.dbs.ux.bind.annotation.QueryParam;
import com.dbs.ux.db.DaoService;
import com.dbs.ux.db.TransactionManager;
import com.dbs.ux.db.page.MxPage;
import com.dbs.ux.db.page.MxPagingVM;
import com.dbs.ux.ui.Component;
import com.dbs.ux.ui.Executions;
import com.dbs.ux.ui.MxConstants;
import com.dbs.ux.ui.MxEvent;
import com.dbs.ux.ui.event.Event;
import com.dbs.ux.ui.event.EventListener;
import com.dbs.ux.ui.event.Events;
import com.dbs.ux.ui.select.Selectors;
import com.dbs.ux.ui.select.annotation.Wire;
import com.dbs.ux.ui.util.Clients;
import com.dbs.uxul.Messagebox;
import com.dbs.uxul.Vlayout;
import com.dbs.uxul.Window;
import com.smartdot.grcsp.commons.util.SysAccessUtils;
import com.smartdot.grcsp.organization.entity.User;
import com.smartdot.icm.module.docrule.entity.DocRule;
import com.smartdot.icm.module.matrix.dao.MtxProcessMapper;
import com.smartdot.icm.module.matrix.entity.MtxProcess;
public class DemoListVM extends MxPagingVM{
private List<MtxProcess> dataList;
@Wire
private Vlayout contentsDemo;
private String processName;
private String processCode;
private String level;
@Init
public void init(@ContextParam(ContextType.VIEW) Component view,@QueryParam("catalog") String catalog) {
super.init(view);
dataList = new ArrayList<MtxProcess>();
loadPageData(1, new HashMap());
}
@AfterCompose
public void afterComposer(@ContextParam(ContextType.VIEW) Component view){
Selectors.wireComponents(view, this, false);
Selectors.wireEventListeners(view, this);
binder = (Binder)view.getAttribute("binder");
}
public void loadPageData(int pageNo, HashMap params){
super.loadPageData(pageNo);
// 调用取得分析接口,返回策略ID列表
DaoService daoService = new DaoService();
MxPage<MtxProcess> resultList = null;
try {
resultList = (MxPage)daoService.get(MtxProcessMapper.class,page).findList(params);
} catch (Exception e) {
e.printStackTrace();
}
page.setTotal(resultList.getTotal());
dataList.clear();
dataList.addAll(resultList);
}
@Command("new") @NotifyChange("dataList")
public void onNew(){
User user = SysAccessUtils.getUser();
Map params = new HashMap();
MtxProcess process = new MtxProcess();
process.setCreatorId(user.getId());
process.setCreatorName(user.getName());
process.setCreateTime(new Date());
process.setModifyTime(new Date());
params.put("entity", process);
params.put("mode", MxConstants.NEW_MODE);
Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params);
window.addEventListener(Events.ON_CLOSE, new EventListener(){
public void onEvent(Event event) throws Exception {
if(event instanceof MxEvent){
MtxProcess mtxPrc = (MtxProcess)event.getData();
dataList.add(mtxPrc);
}
}
});
window.doModal();
}
@Command("edit") @NotifyChange("dataList")
public void onEdit(@BindingParam("entity") MtxProcess entity){
Map params = new HashMap();
params.put("entity", entity);
params.put("mode", MxConstants.EDIT_MODE);
Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params);
window.doModal();
}
@Command("view")
public void onView(@BindingParam("entity") MtxProcess entity){
Map params = new HashMap();
params.put("entity", entity);
params.put("mode", MxConstants.VIEW_MODE);
Window window = (Window)Executions.createComponents("module/docManage/demoEdit.ul", null, params);
window.doModal();
}
@Command("delete")
public void onDelete(@BindingParam("entity") final MtxProcess entity){
try {
int status = Messagebox.show("确认您要删除吗?", "信息", Messagebox.OK
| Messagebox.CANCEL, Messagebox.QUESTION,
new EventListener() {
public void onEvent(Event evt) {
switch (((Integer) evt.getData()).intValue()) {
case Messagebox.OK:
DaoService daoService = new DaoService();
daoService.get(MtxProcessMapper.class).markDelete(entity.getId());
TransactionManager.commit();
dataList.remove(entity);
break;
case Messagebox.CANCEL:
break;
}
}
});
} catch (Exception e) {
TransactionManager.rollback();
e.printStackTrace();
} finally {
TransactionManager.closeSession();
}
}
@Command("search") @NotifyChange("dataList")
public void onSearch(@ContextParam(ContextType.VIEW) Component view){
// search.close();
HashMap<String, String> params = new HashMap<String, String>();
params.put("processName", processName);
params.put("processCode", processCode);
params.put("level", level);
loadPageData(1, params);
contentsDemo.invalidate();
Clients.resize(contentsDemo);
}
public List<MtxProcess> getDataList() {
return dataList;
}
public void setDataList(List<MtxProcess> dataList) {
this.dataList = dataList;
}
public String getProcessName() {
return processName;
}
public void setProcessName(String processName) {
this.processName = processName;
}
public String getProcessCode() {
return processCode;
}
public void setProcessCode(String processCode) {
this.processCode = processCode;
}
public String getLevel() {
return level;
}
public void setLevel(String level) {
this.level = level;
}
public Vlayout getContentsDemo() {
return contentsDemo;
}
public void setContentsDemo(Vlayout contentsDemo) {
this.contentsDemo = contentsDemo;
}
}