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 :
Listbox 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 AMlinkAnother new ZK fiddle
1guest141.101.69.1271plv0hpApr 17, 2024 5:37:43 AMlinkpdf set content media
2guest172.68.18.22635q7pbApr 16, 2024 9:27:52 PMlinkpdf set content media
1guest172.71.234.11635q7pbApr 16, 2024 9:27:06 PMlinkInline editor with multiline textbox example
3guest162.158.155.66dri7ckApr 16, 2024 7:11:00 PMlinkdecimal box limit
14guest162.158.186.241gvsdq0Apr 16, 2024 4:16:51 PMlinkAnother new ZK fiddle
1guest172.68.11.21h7t36lMar 4, 2021 9:37:00 AMlinkresources
index.zulzul<zk>
<window viewModel="@id('vm') @init('pkg$.TestVM')">
<div form="@id('fx') @init(vm.proxy) @load(vm.product) @save(vm.product, before={'save'})">
<textbox value="@bind(fx.prodName)"/>
<listbox model="@bind(fx.prices)">
<listhead>
<listheader label="price"/>
</listhead>
<template name="model" var="p">
<listitem>
<listcell label="@load(p.value)"/>
</listitem>
</template>
</listbox>
<button label="Add Price" onClick="@command('addPrice')"/>
<button label="Save" onClick="@command('save')"/>
</div>
</window>
</zk>
TestVM.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.Command;
import org.zkoss.bind.annotation.Init;
import org.zkoss.bind.annotation.NotifyChange;
import org.zkoss.bind.proxy.ProxyHelper;
public class TestVM {
private Product product;
private Product proxy;
@Init
public void init() {
product = Logic.createProduct();
proxy = ProxyHelper.createFormProxy(product, Product.class);
}
@Command
@NotifyChange("proxy")
public void addPrice() {
Logic.addPrice(proxy);
}
@Command
public void save() {
//here comes error
}
public void setProduct(Product product) {
this.product = product;
}
public Product getProduct() {
return product;
}
public void setProxy(Product proxy) {
this.proxy = proxy;
}
public Product getProxy() {
return proxy;
}
}
Product.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 java.util.Set;
import java.util.HashSet;
public class Product {
private Integer id;
private String prodName;
private Set<Price> prices = new HashSet<>();
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
public void setProdName(String prodName) {
this.prodName = prodName;
}
public String getProdName() {
return prodName;
}
public void setPrices(Set<Price> prices) {
this.prices = prices;
}
public Set<Price> getPrices() {
return prices;
}
}
Price.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 Price {
private Integer id;
private Product product;
private Integer value;
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
public void setProduct(Product product) {
this.product = product;
}
public Product getProduct() {
return product;
}
public void setValue(Integer value) {
this.value = value;
}
public Integer getValue() {
return value;
}
}
Logic.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 java.util.Set;
import java.util.HashSet;
public class Logic {
public static Product createProduct() {
Product product = new Product();
product.setId(1);
product.setProdName("My product");
return product;
}
public static void addPrice(Product product) {
Price price = new Price();
price.setId(1);
price.setValue(10);
product.getPrices().add(price);
price = product.getPrices().stream().findFirst().get();
price.setProduct(product);
}
}