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 AMlinkBig List in Listbox Testing
9leehom111.235.222.89fqth53Dec 6, 2012 6:23:52 AMlinkresources
index.zulzul<zk>
<zscript>
<![CDATA[
void click(){
List items = new pkg$.BigList(1000); //a big list of Integer
if ( items.size() > 500 ) {
Messagebox.show("Over 500 Data.");
}
ListModelList lml = new ListModelList(items);
lml.setMultiple(true);
listbox.setModel(lml);
}
void click2(){
List items = new pkg$.BigList(0); //a big list of Integer
ListModelList lml = new ListModelList(items);
lml.setMultiple(true);
listbox.setModel(lml);
}
void click3(){
Window win = (Window) Executions.createComponents("next.zul",null,null);
win.setClosable(true);
win.doModal();
}
]]>
</zscript>
<button id="btn1" label="Set Data" onClick="click()"/>
<button id="btn2" label="Clear Data" onClick="click2()"/>
<button id="btn3" label="popup window" onClick="click3()"/>
<listbox id="listbox" multiple="true" checkmark="true" height = "500px" width = "500px"
itemRenderer="pkg$.LbRenderer" >
<custom-attributes org.zkoss.zul.listbox.rod = "false">
</custom-attributes>
<listhead>
<listheader width="30px" />
<listheader label = "1" />
<listheader label = "2" />
<listheader label = "3" />
<listheader label = "4" />
</listhead>
<listitem forEach="${items}">
<listcell />
<listcell label="${each}-1" />
<listcell label="${each}-2" />
<listcell label="${each}-3" />
<listcell label="${each}-4" />
</listitem>
</listbox>
</zk>
LbRenderer.javajavaimport org.zkoss.zul.Listcell;
import org.zkoss.zul.Listitem;
import org.zkoss.zul.ListitemRenderer;
public class LbRenderer implements ListitemRenderer<Integer> {
@Override
public void render(Listitem li, Integer bl, int idx) throws Exception {
new Listcell("").setParent(li);
new Listcell(bl+"-1").setParent(li);
new Listcell(bl+"-2").setParent(li);
new Listcell(bl+"-3").setParent(li);
new Listcell(bl+"-4").setParent(li);
}
}
BigList.javajava
import java.util.AbstractList;
public class BigList extends AbstractList<Integer> {
private int size;
public BigList(int sz) {
if (sz < 0)
throw new IllegalArgumentException("Negative not allowed: " + sz);
size = sz;
}
public int size() {
return size;
}
public Integer get(int j) {
return Integer.valueOf(j);
}
}next.zulzul
<zk>
<window id="win1" title="popup" border="normal" position="center,center" width="600px" height="600px" >
<zscript>
<![CDATA[
void click5(){
List items = new pkg$.BigList(1000); //a big list of Integer
if ( items.size() > 500 ) {
Messagebox.show("Over 500 Data.");
}
ListModelList lml = new ListModelList(items);
lml.setMultiple(true);
listbox1.setModel(lml);
}
void click6(){
List items = new pkg$.BigList(0); //a big list of Integer
ListModelList lml = new ListModelList(items);
lml.setMultiple(true);
listbox1.setModel(lml);
}
]]>
</zscript>
<button id="btn5" label="Set Data" onClick="click5()"/>
<button id="btn6" label="Clear Data" onClick="click6()"/>
<listbox id="listbox1" multiple="true" checkmark="true" height = "500px" width = "500px"
itemRenderer="pkg$.LbRenderer" >
<custom-attributes org.zkoss.zul.listbox.rod = "false">
</custom-attributes>
<listhead>
<listheader width="30px" />
<listheader label = "1" />
<listheader label = "2" />
<listheader label = "3" />
<listheader label = "4" />
</listhead>
<listitem forEach="${items}">
<listcell />
<listcell label="${each}-1" />
<listcell label="${each}-2" />
<listcell label="${each}-3" />
<listcell label="${each}-4" />
</listitem>
</listbox>
</window>
</zk>