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 :
Another new ZK fiddle
176guest172.69.254.13419a19qgMay 17, 2024 8:45:43 AMlinkDynamic Listbox Columns
1guest172.70.83.1082em2ouuMay 16, 2024 7:13:53 PMlinkError dialog
2guest162.158.155.1062g9n9d2May 16, 2024 3:07:42 PMlinkError dialog
1guest172.70.231.542g9n9d2May 16, 2024 3:06:24 PMlinkMVVM dependent comboboxes
12guest141.101.68.25184fg41May 16, 2024 2:16:55 PMlinkAnother new ZK fiddle
1guest162.158.187.82r09jvbMay 16, 2024 3:23:08 AMlinkopen popup with callback
1guest108.162.212.149790u9iMay 15, 2024 11:53:18 PMlinkopen popup with callback
30guest108.162.212.1491kje9rvMay 15, 2024 11:52:46 PMlinkPDFObject - ZK
63guest172.69.214.221hlaak0May 14, 2024 5:27:57 PMlinkEmailTemplate-Asim
1guest141.101.76.232ivbacvMay 14, 2024 4:27:59 PMlinkListbox with Dynamic Template
1guest220.135.202.140pkigdeMay 26, 2014 10:12:39 AMlinkresources
index.zulzul<zk>
<vlayout vflex="1" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.ListboxVM')">
<button label="Change Type" onClick="@command('changeType')" />
<listbox vflex="1" model="@load(vm.datas) @template(vm.type ? 'model1' : 'model2')">
<listhead children="@load(vm.type ? vm.headers1 : vm.headers2) @template('header')">
<template name="header">
<listheader label="@load(each)" />
</template>
</listhead>
<template name="model1" var="item">
<listitem>
<listcell label="@load(item.columnA)" />
<listcell label="@load(item.columnB)" />
<listcell label="@load(item.columnC)" />
</listitem>
</template>
<template name="model2" var="item">
<listitem>
<listcell label="@load(item.columnD)" />
<listcell label="@load(item.columnE)" />
<listcell label="@load(item.columnF)" />
<listcell label="@load(item.columnG)" />
</listitem>
</template>
<listfoot children="@load(vm.type ? vm.footers1 : vm.footers2) @template('footer')">
<template name="footer">
<listfooter label="@load(each)" />
</template>
</listfoot>
</listbox>
</vlayout>
</zk>ListboxVM.javajavaimport java.util.ArrayList;
import java.util.List;
import org.zkoss.bind.annotation.Command;
import org.zkoss.bind.annotation.Init;
import org.zkoss.bind.annotation.NotifyChange;
public class ListboxVM {
private boolean type;
private List<String> headers1, headers2;
private List<String> footers1, footers2;
private List<Item> datas;
@Init
public void init() {
type = true;
headers1 = new ArrayList<String>();
headers1.add("Column A");
headers1.add("Column B");
headers1.add("Column C");
headers2 = new ArrayList<String>();
headers2.add("Column D");
headers2.add("Column E");
headers2.add("Column F");
headers2.add("Column G");
footers1 = new ArrayList<String>();
footers1.add("Footer A");
footers1.add("Footer B");
footers1.add("Footer C");
footers2 = new ArrayList<String>();
footers2.add("Footer D");
footers2.add("Footer E");
footers2.add("Footer F");
footers2.add("Footer G");
datas = new ArrayList<Item>();
for (int i = 0; i < 30; i++) {
datas.add(new Item(i % 2 == 0,
"Cell A" + i, "Cell B" + i, "Cell C" + i,
"Cell D" + i, "Cell E" + i, "Cell F" + i, "Cell G" + i));
}
}
@Command
@NotifyChange("type")
public void changeType() {
type = !type;
}
public boolean isType() {
return type;
}
public void setType(boolean type) {
this.type = type;
}
public List<String> getHeaders1() {
return headers1;
}
public void setHeaders1(List<String> headers1) {
this.headers1 = headers1;
}
public List<String> getHeaders2() {
return headers2;
}
public void setHeaders2(List<String> headers2) {
this.headers2 = headers2;
}
public List<String> getFooters1() {
return footers1;
}
public void setFooters1(List<String> footers1) {
this.footers1 = footers1;
}
public List<String> getFooters2() {
return footers2;
}
public void setFooters2(List<String> footers2) {
this.footers2 = footers2;
}
public List<Item> getDatas() {
return datas;
}
public void setDatas(List<Item> datas) {
this.datas = datas;
}
public class Item {
private boolean groupABC;
private String columnA, columnB, columnC;
private String columnD, columnE, columnF, columnG;
public Item(boolean groupABC, String columnA, String columnB,
String columnC, String columnD, String columnE, String columnF,
String columnG) {
this.groupABC = groupABC;
this.columnA = columnA;
this.columnB = columnB;
this.columnC = columnC;
this.columnD = columnD;
this.columnE = columnE;
this.columnF = columnF;
this.columnG = columnG;
}
public boolean isGroupABC() {
return groupABC;
}
public void setGroupABC(boolean groupABC) {
this.groupABC = groupABC;
}
public String getColumnA() {
return columnA;
}
public void setColumnA(String columnA) {
this.columnA = columnA;
}
public String getColumnB() {
return columnB;
}
public void setColumnB(String columnB) {
this.columnB = columnB;
}
public String getColumnC() {
return columnC;
}
public void setColumnC(String columnC) {
this.columnC = columnC;
}
public String getColumnD() {
return columnD;
}
public void setColumnD(String columnD) {
this.columnD = columnD;
}
public String getColumnE() {
return columnE;
}
public void setColumnE(String columnE) {
this.columnE = columnE;
}
public String getColumnF() {
return columnF;
}
public void setColumnF(String columnF) {
this.columnF = columnF;
}
public String getColumnG() {
return columnG;
}
public void setColumnG(String columnG) {
this.columnG = columnG;
}
}
}