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 :
Customized Menupopup On Grid Header
5hiepgau172.71.211.10gig0j7May 4, 2024 5:33:29 AMlinkAnother new ZK fiddle
4hiepgau172.68.225.142gig0j7May 4, 2024 5:31:25 AMlinkAnother new ZK fiddle
3hiepgau172.71.218.113gig0j7May 3, 2024 11:46:46 PMlinkAnother new ZK fiddle
2hiepgau162.158.178.201gig0j7May 3, 2024 11:40:57 PMlinkAnother new ZK fiddle
1hiepgau162.158.179.103gig0j7May 3, 2024 10:49:45 PMlinkcustom menu on grid
7hiepgau172.71.214.52261rcaiMay 3, 2024 9:27:35 PMlinkcustom menu on grid
6hiepgau172.71.214.53261rcaiMay 3, 2024 9:26:52 PMlinkcustom menu on grid
5hiepgau172.71.214.53261rcaiMay 3, 2024 9:25:26 PMlinkcustom menu on grid
4hiepgau162.158.114.139261rcaiMay 3, 2024 9:20:17 PMlinkAnother new ZK fiddle
1guest172.70.80.2021nil9qsMay 3, 2024 2:07:26 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;
}
}
}