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 :
ComboBox - Selection with Checkboxes
25guest162.158.187.7elaaadMar 29, 2024 7:57:07 AMlinkComboBox - Selection with Checkboxes
24guest172.70.206.179elaaadMar 29, 2024 7:27:32 AMlinkcheck
244guest172.71.126.18620t2jmoMar 29, 2024 7:08:48 AMlinkfrozen scroll
1guest172.69.33.373j82a06Mar 28, 2024 8:03:44 AMlinkGmarker and forEach
1guest172.68.67.1362lpvk1hMar 28, 2024 7:29:50 AMlinkGmaps
1guest172.68.67.1363dvghg5Mar 28, 2024 7:28:20 AMlinkgrid demo
5guest172.71.158.2371grhhu3Mar 27, 2024 7:46:36 AMlinkgrid demo
4guest172.71.158.2371grhhu3Mar 27, 2024 7:46:25 AMlinkgrid demo
3guest172.71.154.181grhhu3Mar 27, 2024 7:44:16 AMlinkgrid demo
2guest172.71.154.181grhhu3Mar 27, 2024 7:43:58 AMlinkupdate/add/delete data grid
9guest94.126.240.21bi6pjpOct 10, 2018 12:05:53 PMlinkresources
index.zulzul<zk xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.zkoss.org/2005/zul/zul.xsd">
<separator></separator>
<window vflex="true" position="center" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.TestVM')">
<vlayout>
<label value="VALORACIONES FILMS" style="text-align: center;font-weight: bold;"/>
<separator></separator>
<separator></separator>
<hbox>
<grid width="700px" model="@load(vm.listaPeliculas)">
<columns>
<column width="20%" label="Titulo"/>
<column width="20%" label="Fecha"/>
<column width="10%" label="Nota"/>
<column width="30%" label="Observaciones"/>
<column width="10%" />
<column width="10%" />
</columns>
<template name="model">
<row>
<label value="@load(each.titulo)" />
<label value="@load(each.fecha)" />
<label value="@load(each.nota)" />
<textbox value="@load(each.observaciones)" disabled="true"/>
<button label="B" onClick="@command('borrar', pelicula=each)" />
</row>
</template>
</grid>
<button label="+" onClick="@command('add')"/>
</hbox>
</vlayout>
</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 java.util.*;
import org.zkoss.bind.annotation.*;
public class TestVM extends GenericForwardComposer{
private List<Pelicula> listaPeliculas = new ArrayList<Pelicula>();
@Init
public void init(){
listaPeliculas = new ArrayList();
listaPeliculas.add(new Pelicula("Vengadores", "07-10-2018", 5.0, "observaciones 1"));
listaPeliculas.add(new Pelicula("El Rey Leon", "07-10-2018", 10.0, "observaciones 2"));
listaPeliculas.add(new Pelicula("Mision Imposible 1", "07-10-2018", 8.5, "observaciones 3"));
}
@Command
@NotifyChange("listaPeliculas")
public void borrar(@BindingParam("pelicula") Pelicula p) {
listaPeliculas.remove(p);
}
@Command
@NotifyChange("listaPeliculas")
public void add(){
Map<String, Object> args = new HashMap<String, Object>();
args.put("pelicula", new Pelicula("", "", 0.0,""));
Executions.createComponents("ventanaAdd.zul", null, args);
}
@GlobalCommand
@NotifyChange("listaPeliculas")
public void agregarPelicula(@BindingParam("pelicula")Pelicula pelicula){
listaPeliculas.add(pelicula);
}
public List<Pelicula> getListaPeliculas(){
return listaPeliculas;
}
public void setListaPeliculas(List<Pelicula> lista){
this.listaPeliculas=lista;
}
}
Pelicula.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 Pelicula extends GenericForwardComposer{
private String titulo;
private String fecha;
private Double nota;
private String observaciones;
public Pelicula(String titulo, String fecha, Double nota, String observaciones){
this.titulo=titulo;
this.fecha=fecha;
this.nota=nota;
this.observaciones=observaciones;
}
public String getTitulo() {
return titulo;
}
public void setTitulo(String titulo) {
this.titulo = titulo;
}
public String getFecha() {
return fecha;
}
public void setFecha(String fecha) {
this.fecha = fecha;
}
public Double getNota() {
return nota;
}
public void setNota(Double nota) {
this.nota = nota;
}
public String getObservaciones() {
return observaciones;
}
public void setObservaciones(String observaciones) {
this.observaciones = observaciones;
}
}
ventanaAdd.zulzul<zk>
<window id="modalDialog" vflex="true" position="center" apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.ventanaAddVM')" closable="true"
action="show: slideDown;hide: slideUp" mode="modal" >
<vlayout>
<grid width="700px">
<rows>
<row>
<label value="Titulo"/>
<hlayout>
<textbox value="@bind(vm.selected.titulo)"/>
</hlayout>
</row>
<row>
<label value="Fecha"/>
<hlayout>
<textbox value="@bind(vm.selected.fecha)"/>
</hlayout>
</row>
<row>
<label value="Nota"/>
<hlayout>
<textbox value="@bind(vm.selected.nota)"/>
</hlayout>
</row>
<row>
<label value="Observaciones"/>
<hlayout>
<textbox value="@bind(vm.selected.observaciones)"/>
</hlayout>
</row>
</rows>
</grid>
<div style="float: right;">
<button hflex="1" label="Cerrar" onClick="modalDialog.detach();"/>
<button hflex="1" label="Aceptar" onClick="@command('aceptar', pelicula=vm.selected)"/>
</div>
</vlayout>
</window>
</zk>
ventanaAddVM.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.*;
import org.zkoss.bind.annotation.AfterCompose;
import org.zkoss.bind.annotation.*;
import org.zkoss.zk.ui.select.annotation.Listen;
import org.zkoss.zk.ui.select.annotation.Wire;
import org.zkoss.zk.ui.Component;
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.select.SelectorComposer;
import org.zkoss.zul.Window;
import org.zkoss.bind.BindUtils;
public class ventanaAddVM extends GenericForwardComposer{
public Pelicula selected;
@AfterCompose
public void init(@ExecutionArgParam("pelicula") Pelicula pelicula) {
selected = pelicula;
}
public Pelicula getSelected(){
return selected;
}
public void setSelected(Pelicula pelicula){
this.selected=pelicula;
}
@Command
public void aceptar(@ContextParam(ContextType.VIEW) Window comp, @BindingParam("pelicula") Pelicula p){
comp.detach();
Map<String,Object> arg = new HashMap<String,Object>();
arg.put("pelicula", p);
BindUtils.postGlobalCommand(null, null, "agregarPelicula", arg);
}
}