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 :

Another new ZK fiddle

1guest172.71.102.2301fgjpg9May 1, 2024 11:20:42 AMlink

basic upload button

37guest172.68.31.1503nocidtApr 30, 2024 6:00:06 PMlink

basic upload button

36guest172.68.31.1513nocidtApr 30, 2024 5:59:30 PMlink

listbox styles

35guest162.158.129.2261nctej6Apr 30, 2024 2:19:32 PMlink

combobox width

14guest172.69.11.155jndu8mApr 29, 2024 6:25:05 PMlink

combobox popup width

3guest172.71.234.16775d532Apr 29, 2024 2:00:04 PMlink

Barcodescanner use in Modal Window (with constraint)

2guest172.71.246.120tcutf2Apr 26, 2024 1:52:52 PMlink

Barcodescanner use in Modal Window (with constraint)

1guest172.71.246.120tcutf2Apr 26, 2024 1:52:28 PMlink

Barcodescanner use in Modal Window (with constraint)

1guest162.158.87.361sd60hgApr 26, 2024 1:40:19 PMlink

Simple Tree

3guest172.70.162.811cm49soApr 26, 2024 11:34:34 AMlink

Columns and Cells not in sync after appending column

2guest145.253.186.1302im5kjgFeb 19, 2019 1:46:30 PMlink

resources

index.zulzul<!-- Steps to reproduce: 1) Click "Append Column" 2) Click "Show all" 3) Scroll to the right. The bdfaker is missing. Headers are not in sync with cells. --> <zk> <window apply="pkg$.TestComposer"> <hlayout hflex="1" vflex="1"> <panel hflex="1" vflex="1"> <panelchildren> <grid id="grid" height="800px" width="1300px"> <columns></columns> <rows></rows> </grid> </panelchildren> </panel> <button id="appendColumn" label="Append Column"/> <button id="showContent" label="Show all"/> </hlayout> </window> </zk>TestComposer.javajavaimport org.zkoss.zk.ui.Component; import org.zkoss.zk.ui.select.SelectorComposer; import org.zkoss.zk.ui.select.annotation.Wire; import org.zkoss.zul.Button; import org.zkoss.zul.Cell; import org.zkoss.zul.Column; import org.zkoss.zul.Grid; import org.zkoss.zul.Label; import org.zkoss.zul.ListModelList; import org.zkoss.zul.RowRenderer; import org.zkoss.zul.Window; import java.util.ArrayList; import java.util.List; public class TestComposer extends SelectorComposer<Window> { protected int numberOfAdditionalCols = 3; private static final int NUMBER_OF_ROWS = 1000; @Wire private Grid grid; @Wire private Button appendColumn; @Wire private Button showContent; private ListModelList<TestListItem> model; private List<TestListItem> itemList; public void doAfterCompose(Window comp) throws Exception { super.doAfterCompose(comp); model = new ListModelList<>(); grid.setModel(model); for (int i = 0; i < numberOfAdditionalCols; i++) { Column name = new Column("Name"); name.setWidth("400px"); grid.getColumns().getChildren().add(name); } RowRenderer renderer = new MyRowRenderer(this, grid); grid.setRowRenderer(renderer); setData(); model.addAll(itemList.subList(0,10)); appendColumn.addEventListener("onClick", event -> appendColumn()); showContent.addEventListener("onClick", event -> showAll()); } private void showAll() { model.clear(); model.addAll(itemList); } public void appendColumn() { Column col = new Column("Name"); col.setWidth("400px"); grid.getColumns().appendChild(col); for(Component row: grid.getRows().getChildren()) { Cell cell = new Cell(); cell.appendChild(new Label("name 3")); row.appendChild(cell); } numberOfAdditionalCols++; } private List<TestListItem> setData() { ArrayList<TestListItem> list = new ArrayList<>(); itemList = new ArrayList<>(); for (int i = 0; i < NUMBER_OF_ROWS; i++) { list.add(createAndAddItem("name" + i)); } this.itemList = new ArrayList<>(list); return list; } private TestListItem createAndAddItem(String name) { final TestListItem testItem = new TestListItem(); testItem.setName(name); return testItem; } }MyRowRenderer.javajavaimport org.zkoss.zk.ui.util.Clients; import org.zkoss.zul.Cell; import org.zkoss.zul.Grid; import org.zkoss.zul.Label; import org.zkoss.zul.RendererCtrl; import org.zkoss.zul.Row; import org.zkoss.zul.RowRenderer; public class MyRowRenderer implements RowRenderer<Object>, RendererCtrl { private Grid grid; private TestComposer composer; public MyRowRenderer(TestComposer composer, Grid grid) { this.grid = grid; this.composer = composer; } public void render(final Row row, final Object data, int index) { for (int i = 0; i < composer.numberOfAdditionalCols; i++) { Cell cell = new Cell(); cell.setParent(row); new Label("name "+i).setParent(cell); } } @Override public void doTry() { } @Override public void doCatch(Throwable ex) throws Throwable { } @Override public void doFinally() { } } TestListItem.javajavaimport org.zkoss.idom.Document; import org.zkoss.idom.Group; import org.zkoss.idom.Item; import org.zkoss.xml.Locator; import java.math.BigDecimal; public class TestListItem implements Item { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String getText() { return null; } @Override public void setText(String s) { } @Override public Document getDocument() { return null; } @Override public Item detach() { return null; } @Override public Group getParent() { return null; } @Override public Locator getLocator() { return null; } @Override public void setLocator(Locator locator) { } @Override public Object clone() { return null; } @Override public void setParent(Group group) { } }