Processing...

Suggested case list:

Using timer to refresh a grid

383guest172.69.33.12125nk0uiMay 7, 2020 7:23:47 AMlink

user model to move item to another listbox

120guest162.158.193.148d0n3krApr 2, 2020 5:28:28 AMlink

Disabled list item row passed to VM-1981

296fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:44 PMlink

Disabled list item row passed to VM-1981

295fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:16 PMlink

Disabled list item row passed to VM-1981

294fatih123160.83.36.13225nk0uiFeb 13, 2018 3:30:44 PMlink

grid sample with ListModel/RowRenderer

816guest80.82.2.1312vah9ajFeb 21, 2017 11:42:21 AMlink

grid sample with ListModel/RowRenderer

809guest175.98.113.1622vah9ajJan 26, 2017 9:19:33 AMlink

grid sample with ListModel/RowRenderer

196guest79.185.142.402vah9ajApr 26, 2014 10:53:57 PMlink

grid sample with ListModel/RowRenderer

195guest79.185.142.402vah9ajApr 26, 2014 10:53:54 PMlink

grid sample with ListModel/RowRenderer

194guest79.185.142.402vah9ajApr 26, 2014 10:53:51 PMlink

grid sample with ListModel/RowRenderer

193guest79.185.142.402vah9ajApr 26, 2014 10:53:48 PMlink

grid sample with ListModel/RowRenderer

192guest79.185.142.402vah9ajApr 26, 2014 10:53:44 PMlink

grid sample with ListModel/RowRenderer

191guest79.185.142.402vah9ajApr 26, 2014 10:53:40 PMlink

Hierarchy table without using ZK PE/EE

1aaknai151.28.135.2131s871daJul 29, 2013 11:02:46 PMlink

grid sample with ListModel/RowRenderer

128aaknai151.28.135.2132vah9ajJul 29, 2013 7:20:00 PMlink

user model to move item to another listbox

1TonyQ114.25.109.94d0n3krApr 21, 2012 10:43:27 AMlink

Using timer to refresh a grid

1TonyQ220.133.44.3725nk0uiFeb 17, 2012 3:17:34 AMlink

Fire a event from child iframe

1TonyQ220.133.44.372eupjotFeb 3, 2012 5:04:52 AMlink

Textbox input restriction sample

1TonyQ72.21.245.2431b3nlr0Dec 20, 2011 10:09:10 AMlink

Test web core taglib in ZUL

1TonyQ198.203.175.175ofqkemDec 17, 2011 3:36:08 AMlink

Latest 10 Fiddles :

constraint binding textbox

3guest172.68.151.16220peldaDec 5, 2025 5:08:19 PMlink

Another new ZK fiddle

2guest172.68.151.16320peldaDec 5, 2025 5:07:51 PMlink

Another new ZK fiddle

1guest172.68.151.16220peldaDec 5, 2025 5:07:32 PMlink

Another new ZK fiddle

1peggypeng172.71.154.99364f4neDec 5, 2025 9:24:31 AMlink

tooltip example

2guest104.22.23.13rc1ntoDec 4, 2025 2:23:45 PMlink

Another new ZK fiddle

1guest172.69.134.2277t7602Dec 4, 2025 1:40:46 PMlink

Another new ZK fiddle

1peggypeng104.22.17.1802df6e3oDec 4, 2025 8:41:29 AMlink

onClose

1peggypeng172.68.87.248j8kd8aDec 3, 2025 4:10:26 AMlink

Another new ZK fiddle

1peggypeng172.69.134.2271rm7f4eNov 26, 2025 3:31:24 AMlink

ZK-5912-Suggestion

2rebeccalai104.22.20.1442qrmiiuNov 26, 2025 2:07:15 AMlink

Clients.evalJavaScript

122guest162.158.22.1292kbd391Sep 26, 2025 3:46:55 PMlink

resources

index.zulzul<zk> <style> .dirty { color: #AA2222; } </style> <window apply="org.zkoss.bind.BindComposer" viewModel="@id('vm') @init('pkg$.TestVM')"> <script src="phone.js?v=2" /> <div width="200px"> <label value="@load(vm.msg)" style="width: 300px;" /> </div> <button id="btnPing" label="Ping" onClick="@command('ping')" /> <button id="btn" label="test" onTest="@command('test')" /> <button label="test two" forward="onClick=btn.onTest" /> <button label="test three"> <attribute name="onClick"> Clients.evalJavaScript("doTest();"); </attribute> </button> <div style="padding-top: 0px;" width="100%" height="100%"> <html> <script> <![CDATA[ function initMapContext() { var mymap = L.map('mapCanvas').setView([33, -6], 13); L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png', { maxZoom: 18, attribution: 'Map data; <a href="http://www.caciopee.com/">Caciopee</a>, ' + '<a href="http://www.caciopee.com/index.php/works">Works</a> ' + '', id: 'mapbox.streets' }).addTo(mymap); } ]]> </script> <div id="mapCanvas" style="height: 700px;margin: 0px; padding: 0px; width:100%" /> </html> </div> </window> </zk>TestVM.javajava import org.zkoss.bind.BindContext; import org.zkoss.bind.Form; import org.zkoss.bind.ValidationContext; import org.zkoss.bind.Validator; import org.zkoss.bind.annotation.Command; import org.zkoss.bind.annotation.NotifyChange; import org.zkoss.bind.annotation.ContextParam; import org.zkoss.bind.annotation.ContextType; import org.zkoss.zul.*; import org.zkoss.zk.ui.Component; import org.zkoss.zk.ui.event.Event; import org.zkoss.bind.annotation.*; import org.zkoss.zk.ui.select.Selectors; import org.zkoss.zk.ui.Component; import org.zkoss.zk.ui.HtmlBasedComponent; import org.zkoss.zk.ui.event.Event; import org.zkoss.zk.ui.event.EventListener; import org.zkoss.zk.ui.select.annotation.*; import org.zkoss.zk.ui.util.Clients; public class TestVM implements EventListener<Event>{ @Wire public void init() { } @AfterCompose public void afterCompose(@ContextParam(ContextType.VIEW) Component view) throws Exception { //com.caciopee.genie.ui.WorksSelectors.wireComponents(view, this, false); Selectors.wireEventListeners(view, this); Clients.evalJavaScript("initMapContext();"); } private String _msg = "before test"; public String getMsg() { return _msg; } @Command @NotifyChange("msg") public void test () { _msg = "after test"; } @Command @NotifyChange("msg") public void ping () { _msg = "ping"; Clients.evalJavaScript("ping();"); } @Override public void onEvent(Event evt) throws Exception { } }phone.jsjavascriptvar windowId; var selectorId; var textboxId; var myWindow; var inputStylishPhone; var txtPhone; function doPing() { alert("doPing"); } function refreshValue(){ console.log("refreshValue=" + this.id); phoneId = this.id; windowId = "$win"+phoneId; textboxId = "$txt"+phoneId; selectorId = "#"+phoneId; myWindow = zk.Widget.$(windowId); txtPhone = zk.Widget.$(textboxId); inputStylishPhone = document.querySelector(selectorId); txtPhone.setValue(this.value); // alert("-windowId "+windowId+ " -myWindow "+myWindow+ "-selectorId "+selectorId+" -inputStylishPhone "+inputStylishPhone.value); var value = txtPhone.getValue(); if(value!=null && !value.startsWith('+')){ //var dialCode = this.previousSibling.firstChild.firstChild.nextSibling.innerHTML; (if separateDialCode) var dialCode = this.previousSibling.firstChild.title; dialCode = "+" + dialCode.split('+')[1]; value = dialCode+value; } zAu.send(new zk.Event(myWindow, 'onRefreshValue', value)); } function initComponent(){ console.log("initComponent"); } function initComponent(phoneId, phoneValue, varOnlyCountries, varPreferredCountries){ console.log("initComponent=" + phoneId); var arrayOnlyCountries; var arrayPreferredCountries; if(varOnlyCountries!="NONE" ){ arrayOnlyCountries= varOnlyCountries.split(","); } if(varPreferredCountries!="NONE" ){ arrayPreferredCountries = varPreferredCountries.split(","); } windowId = "$win"+phoneId; textboxId = "$txt"+phoneId; selectorId = "#"+phoneId; myWindow = zk.Widget.$(windowId); txtPhone = zk.Widget.$(textboxId); inputStylishPhone = document.querySelector(selectorId); console.log("selectorId=" + selectorId); console.log("inputStylishPhone=" + inputStylishPhone); if (inputStylishPhone != null) { inputStylishPhone.value = phoneValue; txtPhone.setValue(phoneValue); // alert("-windowId "+windowId+ " -myWindow "+myWindow+" -phoneValue "+phoneValue + "-selectorId "+selectorId+" -inputStylishPhone "+inputStylishPhone.value); if(arrayOnlyCountries!=null){ window.intlTelInput(inputStylishPhone, { formatOnDisplay: false, separateDialCode: false, preferredCountries: varPreferredCountries.split(",") , onlyCountries: varOnlyCountries.split(","), utilsScript: "phone/js/utils.js", }); }else{ window.intlTelInput(inputStylishPhone, { formatOnDisplay: false, separateDialCode: false, preferredCountries: varPreferredCountries.split(",") , utilsScript: "phone/js/utils.js", }); } inputStylishPhone.addEventListener('change', refreshValue); inputStylishPhone.addEventListener('blur', refreshValue); } }