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 :
Object hashcode different with ZK form binding
2YannUnil172.69.108.13540rj0kApr 19, 2024 1:18:08 PMlinkObject hashcode different with ZK form binding
1YannUnil172.69.108.13040rj0kApr 19, 2024 1:04:31 PMlinkfont awesome effects
1guest172.71.166.21232nla3hApr 18, 2024 6:04:43 PMlinkfont awesome effects
245guest172.71.166.21220t2jmoApr 18, 2024 6:04:41 PMlinkZK-5696
1JamesChu162.158.187.3739iuvhmApr 18, 2024 10:33:52 AMlinkListbox colspan header version 2
3guest172.71.183.199jkpp6qApr 17, 2024 1:54:19 PMlinkZK-5695
1guest162.158.90.1402is2rctApr 17, 2024 10:23:20 AMlinkLocalDate in datebox
2guest172.70.243.516v49n7Apr 17, 2024 6:05:17 AMlinkLocalDate in datebox
1guest172.70.243.516v49n7Apr 17, 2024 6:04:18 AMlinkLocalDate in datebox
1guest172.70.243.511m6i0gcApr 17, 2024 6:04:04 AMlinkSwitch 2 tabs, doesn't register
3guest37.186.144.2542gmeisdJul 12, 2019 7:33:10 AMlinkresources
index.zulzul<zk>
<window border="normal" viewModel="@id('vm') @init('pkg$.AppVM')" title="hello">
<button id="btn" label="Select Tab 2_2" onClick="@command('selectTab2_2')"/>
<tabbox id="tbx" model="@load(vm.tabInfos)" selectedTab="@bind(vm.selectedTab)"
height="500px" width="500px">
<tabs id="tabs">
<template name="model:tab">
<tab label="@load(each.label)" />
</template>
</tabs>
<tabpanels style="border:0">
<template name="model:tabpanel">
<tabpanel vflex="1" hflex="1" style="overflow:auto;border-width:0" >
<include src="@load(each.contentSrc)" vflex="1" />
</tabpanel>
</template>
</tabpanels>
</tabbox>
</window>
</zk>
AppVM.javajavaimport org.zkoss.zk.ui.*;
import org.zkoss.zk.ui.event.*;
import org.zkoss.zk.ui.util.*;
import org.zkoss.zk.ui.ext.*;
import org.zkoss.zk.au.*;
import org.zkoss.zk.au.out.*;
import org.zkoss.zul.*;
import org.zkoss.bind.annotation.*;
import org.zkoss.bind.*;
import java.util.HashMap;
public class AppVM {
@Init
void init() {
TabInfo tab1 = new TabInfo("tab_1","Tab 1", "tab_1.zul");
createAndSelectTabInfo(tab1);
TabInfo tab2 = new TabInfo("tab_2","Tab 2", "tab_2.zul");
createAndSelectTabInfo(tab2);
selectedTab = tab1;
}
@Command
public void selectTab2_2(){
//TODO
BindUtils.postGlobalCommand(null, null, "addTab2", new HashMap<>());
BindUtils.postGlobalCommand(null, null, "addTab2_2", new HashMap<>());
}
@GlobalCommand("addTab1")
public void addTab1(){
TabInfo tab1 = new TabInfo("tab_1","Tab 1", "tab_1.zul");
createAndSelectTabInfo(tab1);
}
@GlobalCommand("addTab2")
public void addTab2(){
TabInfo tab2 = new TabInfo("tab_2","Tab 2", "tab_2.zul");
createAndSelectTabInfo(tab2);
}
//TABPANELS
ListModelList<TabInfo> tabInfos = new ListModelList<>();
TabInfo selectedTab;
public TabInfo getSelectedTab() {
return selectedTab;
}
public void setSelectedTab(TabInfo selectedTab) {
this.selectedTab = selectedTab;
}
public ListModelList<TabInfo> getTabInfos() {
return tabInfos;
}
public void createAndSelectTabInfo(TabInfo tabInfo) {
TabInfo tab = tabsContains(tabInfos,tabInfo.getId());
if(tab == null){
tab = tabInfo;
tabInfos.add(tab);
}
setSelectedTab(tab);
BindUtils.postNotifyChange(null, null, this, "tabInfos");
BindUtils.postNotifyChange(null, null, this, "selectedTab");
}
protected TabInfo tabsContains(ListModelList<TabInfo> tabInfos,String id) {
if(tabInfos != null && id != null){
for(TabInfo tab : tabInfos){
if(id.equals(tab.getId())){
return tab;
}
}
}
return null;
}
}
TabInfo.javajavaimport org.zkoss.zk.ui.*;
import org.zkoss.zk.ui.event.*;
import org.zkoss.zk.ui.util.*;
import org.zkoss.zk.ui.ext.*;
import org.zkoss.zk.au.*;
import org.zkoss.zk.au.out.*;
import org.zkoss.zul.*;
public class TabInfo {
private String id;
private String label;
private String contentSrc;
public TabInfo (String id, String label, String contentSrc) {
this.id = id;
this.label = label;
this.contentSrc = contentSrc;
}
public void setId(String id) {
this.id = id;
}
public String getId() {
return id;
}
public void setLabel (String label) {
this.label = label;
}
public String getLabel () {
return this.label;
}
public void setContentSrc (String contentSrc) {
this.contentSrc = contentSrc;
}
public String getContentSrc () {
return this.contentSrc;
}
}
tab_1.zulzul<zk>
<div viewModel="@id('vm') @init('pkg$.Tab1VM')" >
<div>Tab1</div>
</div>
</zk>
Tab1VM.javajavaimport org.zkoss.zk.ui.*;
import org.zkoss.zk.ui.event.*;
import org.zkoss.zk.ui.util.*;
import org.zkoss.zk.ui.ext.*;
import org.zkoss.zk.au.*;
import org.zkoss.zk.au.out.*;
import org.zkoss.zul.*;
import org.zkoss.bind.annotation.*;
import org.zkoss.bind.*;
public class Tab1VM {
@Init
void init() {
}
}
tab_2.zulzul<zk>
<div viewModel="@id('vm') @init('pkg$.Tab2VM')" >
<div>Tab2</div>
<label value="@load(('Selected: ' += vm.selectedTab.label))" />
<tabbox id="tbx" model="@load(vm.tabInfos)" selectedTab="@bind(vm.selectedTab)"
style="border-width:0;" height="300px" width="300px">
<tabs id="tabs">
<template name="model:tab">
<tab label="@load(each.label)" closable="true" onClose="@command('closeTab', page=each)"/>
</template>
</tabs>
<tabpanels style="border:0">
<template name="model:tabpanel">
<tabpanel vflex="1" hflex="1" style="overflow:auto;border-width:0" >
<include src="@load(each.contentSrc)" vflex="1" />
</tabpanel>
</template>
</tabpanels>
</tabbox>
</div>
</zk>
Tab2VM.javajavaimport org.zkoss.zk.ui.*;
import org.zkoss.zk.ui.event.*;
import org.zkoss.zk.ui.util.*;
import org.zkoss.zk.ui.ext.*;
import org.zkoss.zk.au.*;
import org.zkoss.zk.au.out.*;
import org.zkoss.zul.*;
import org.zkoss.bind.annotation.*;
import org.zkoss.bind.*;
public class Tab2VM {
@Init
void init() {
addTab2_1();
}
@GlobalCommand("addTab2_1")
public void addTab2_1(){
TabInfo tab2_1 = new TabInfo("tab_2_1","Tab 2_1", "tab2_1.zul");
createAndSelectTabInfo(tab2_1);
}
@GlobalCommand("addTab2_2")
public void addTab2_2(){
TabInfo tab2_2 = new TabInfo("tab_2_2","Tab 2_2", "tab2_2.zul");
createAndSelectTabInfo(tab2_2);
}
//TABPANELS
ListModelList<TabInfo> tabInfos = new ListModelList<>();
TabInfo selectedTab;
public TabInfo getSelectedTab() {
return selectedTab;
}
public void setSelectedTab(TabInfo selectedTab) {
this.selectedTab = selectedTab;
}
public ListModelList<TabInfo> getTabInfos() {
return tabInfos;
}
public void createAndSelectTabInfo(TabInfo tabInfo) {
TabInfo tab = tabsContains(tabInfos, tabInfo.getId());
if(tab == null){
tab = tabInfo;
tabInfos.add(tab);
}
setSelectedTab(tab);
BindUtils.postNotifyChange(null, null, this, "tabInfos");
BindUtils.postNotifyChange(null, null, this, "selectedTab");
}
protected TabInfo tabsContains(ListModelList<TabInfo> tabInfos,String id) {
if(tabInfos != null && id != null){
for(TabInfo tab : tabInfos){
if(id.equals(tab.getId())){
return tab;
}
}
}
return null;
}
@Command("closeTab")
public void onCloseTab(@BindingParam("page") TabInfo tabInfo) {
int indx = tabInfos.indexOf(tabInfo);
tabInfos.remove(tabInfo);
if(tabInfo == selectedTab && tabInfos != null) {
selectedTab = !tabInfos.isEmpty() ? tabInfos.get(indx-1) : null;
}
BindUtils.postNotifyChange(null, null, this, "selectedTab");
BindUtils.postNotifyChange(null, null, this, "tabInfos");
}
}
tab2_1.zulzul<zk>
<div>
Tab 2_1
</div>
</zk>
tab2_2.zulzul<zk>
<div>
Tab 2_2
</div>
</zk>