- 浏览: 242510 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
bihailantian_:
[/size]我而且额 ...
得到集合中的最后一条记录&和求基数偶数 -
w327569056w:
能发一份吗??谢谢 303430060@qq.com
在线购物系统毕业论文 &图书管理系统毕业论文 -
yuan23:
在线购物的系统,谢谢,464302726@qq.com ...
在线购物系统毕业论文 &图书管理系统毕业论文 -
君心可晴:
作业相关
想参考参考
1035236640@qq.com
LZ ...
在线购物系统毕业论文 &图书管理系统毕业论文 -
smith789:
该交论文了,题目相近,感谢博主!smith5623@126.c ...
在线购物系统毕业论文 &图书管理系统毕业论文
在一个页面中使用多种脚本语言
<zscript language="Java">
var1 = 123;
</zscript>
<zscript language="JavaScript">
var2 = 234;
</zscript>
${value} :赋值
----------自定义控件---------------
<?component name="button" extends="button" style="border:1px solid blue" label="用户权限"?>
<button onClick="check()"/>
使用getZScriptVariable方法来获得zscript中的定义的变量。
使用getZScriptClass和getZScriptMethod方法来获取定义在zscript中的类和方法
如果你想找到某个解释器,可以使用getInterpreter方法先获得解释器,就像下面一样:
page.getInterpreter("JavaScript").getVariable("some"); //interpreter for JavaScript
page.getInterpreter(null).getVariable("some"); //interpreter for default language
特殊字符替换
< 用 <来替换
> 用 >来替换
& 用 &来替换
" 用 "来替换
' 用 '来替换
<zscript>
<![CDATA[ ----- 用CDATA解释器
void myfunc(int a, int b) {
if (a < 0 && b > 0) {
//do something
}
]]>
</zscript>
--------------html里添加命名空间----------
<html xmlns:="http://www.w3.org/1999/xhtml"
xmlns:x="http://www.zkoss.org/2005/zul"
xmlns:zk="http://www.zkoss.org/2005/zk">
<body>hello word!</body>
</hmtl>
------------if unles-------
如果a为1,且b不为2 window 组件就会被创建。
<window if="${a==1}" unless="${b==2}">
...
</window>
------------Switch和Case-------
使用zk元素的switch和case属性,你可以控制ZK页面在一个变量等于某个特定值时才会被执行。
<zk switch="${fruit}">
<zk case="apple">
Evaluated only if ${fruit} is apple
</zk>
<zk case="${special}">
Evaluated only if ${fruit} equals ${special}
</zk>
<zk>
Evaluated only if none of the above cases matches.
</zk>
------------正则表达式---------
<zk switch="${fruit}">
<zk case="/ap*.e/">
Evaluate if the regular expression, ap*.e"., matches the switch condition.
</zk>
</zk>
------------和forEach一起使用---
<zk case="${each}" forEach="apple, orange">
等价于,
<zk case="apple, orange">
------------反复式流程
在下面的例子中,列表项目被创建了三次。每个项目的label分别为"Best", "Better" 和 "God",
<listbox>
<listitem label="${each}" forEach="Best, Better, God"/>
</listbox>
如果你有一个存放对象集合的变量,则可以直接为forEach属性指定它。例如,假如你有一个grades变量,如下。
<zscript>
grades = new String[] {"Best", "Better", "Good"};
</zscript>
然后可以使用forEach属性来迭代此变量。注意,你必须使用EL表达式来指定这个集合。
<listbox>
<listitem label="${each}" forEach="${grades}"/>
</listbox>
迭代(iteration)依赖于forEach属性指定值的类型。
如果是java.util.Collection,就会迭代集合(collection)的每个元素。
如果是java.util.Map,就会迭代map中的每个Map.Entry。
如果是java.util.Iterator,就会迭代迭代器(iterator)中的每个元素。
如果是java.util.Enumeration,就会迭代enumeration中的每个元素。
如果是Object[],int[],short[],byte[],char[],float[]或double[]被指定了,就会迭代数组(array)中的每个元素。
如果是null,什么也不会产生(被忽略)。
如果被指定的不是以上类型,相关元素仅被赋值(evaluated)一次,就好像一个集合只指定了一个单 独的项目。
each变量
在迭代中,一个变量被称为each,通过指定集合的项目被创建并且赋值。在上面的例子中,首次迭代中,each被赋值为"Best",然后是"Better",最后是"Good"。
注意each变量在EL表达式和zscript中都是可访问的。ZK将会保留以前定义的每个变量,并在迭代完每个元素后将其恢复。
-----------------隐含对象------------------
self :组件本身
page :页面,与self.page相同
event: 当前事件
----------------进程指令-------------------
你可以将page指令放置在XML文档的任何地方
<?page [id="..."] [title="..."] [style="..."] [language="xul/html"] zscriptLanguage="Java"]?>
----------------
component指令:
<?component name="mywindow" extends="window" class="MyWindow"?>
...
<mywindow>
...
</mywindow>
等价于下面的代码:
<window use="MyWindow">
...
</window>
----------------
<?import uri="/template/taglibs.zul" directives="taglib, xel-method"?>
----------------
<?link rel="alternate" type="application/rss+xml" title="RSS feed"
href="/rssfeed.php"?>
<?link rel="shortcut icon" type="image/x-icon" href="/favicon.ico"?>
<?link rel="stylesheet" type="text/css" href="~./zul/css/ext.css.dsp"?>
<window title="My App">
My content
</window>
-------------------
unless属性
unless="${ an-EL-expr }"
指定不为相关元素赋值(evaluate)的条件。换句话说,如果条件值为真(false),关联元素及其所有子元素会被忽略。
------------------
forEach属性
forEach="${an-EL-expr}"
forEach="${an-EL-expr},a-value"
有两种格式。第一种,你可以不使用逗号来指定一个值。通常为一个对象集合,这样关联元素可以依靠(against)集合中的每个对象重复被赋值。如果没有指定或为空,此属性会被忽略。如果没有集合对象被指定,仅会被赋值一次就好像有一个单元素的集合被指定。
第二种,你可以指定一个列表,使用逗号分隔各项目。然后,对于列表中的每个值,相关联的元素会被重复执行(he associated element will be evaluated repeatedly against each value in the list)。
----------------------
forEachBegin属性
forEachBegin="an-interger"
forEachBegin="${an-EL-expr}"
被用于forEach 属性,指定迭代(iteration)开始处索引(从0开始)。如果没有指定,迭代会从第一个元素开始,即0。
如果forEachBegin大于或等于元素的数目,则不会发生迭代。
注:forEachBegin.index对于基本的集合,数组和其他类型是绝对的(forEachStatus.index is absolute with respect to the underlying collection, array or other type)。例如,如果
forEachBegin为5 ,forEachStatus.index的第一个值为5。
------------------------
forEachEnd属性
for EachEnd="${ an-EL-expr }"
被用于forEach 属性,指定迭代(iteration)结束处索引(包括此)(从0开始)。如果没有指定,迭代会在最后一个元素处结束。
如果forEachEnd大于或等于元素的数目,则迭代会在最后一个元素处结束。
------------------------
<div fulfill="b1.onClick, b2.onOpen"
onFulfill="Components.wireVariables(self, controller)">
...
</div>
------------------------
forward 属性
forward="target_event_expr"
forward="oringal_event=target_event_expr"
这里target_event_expr 是一个事件表达式。事件表达式被用于为一个组件指定事件。可以使用下面格式中的一个:
event-name
target-id.event-name
id1/id2/id3.event-name
${el-expr}.event-name
此属性用将目标组件一个事件以其他事件名称跳转至另一个组件。这就是所谓的跳转条件(forward condition)。
例如,你可以将button的onClick事件跳转至window,如下:
<window id="w" use="MyWindow">
...
<button lable="Submit" forward="onClick=w.onOK"/>
</window>
------------------------------
<window border="normal" width="100px">
<vbox id="result">
</vbox>
<zscript><![CDATA[
String[] s = {"this is 9", "this is ten more to show",
"this framework", "performance is everything"};
for (int j = 0; j < s.length; ++j) {
Label l = new Label(s[j]);
l.maxlength = 9;
l.hyphen = true;
l.parent = result;
}
]]></zscript>
</window>
------------------------------
orient:控制布局为横向或纵向。
例如:orient="vertical"
-------------单选按钮和单选按钮组--------------
<radiogroup onCheck="alert(self.selectedItem.label)">
<radio label="Apple"/>
<radio label="Orange"/>
<radio label="Banana"/>
</radiogroup>
----------------图像------------------
<imagemap src="/img/sun.jpg" onClick="alert(event.x + ", " +event.y)"/>
等价于:
通过为imagemap然后,组件添加area子组件,开发人员可以代替使用应用程序本身处理坐标的方法。
<imagemap src="/img/sun.jpg" onClick="alert(event.area)">
<area id="First" coords="0, 0, 100, 100"/>
<area id="Second" shape="circle" coords="200, 200, 100"/>
</imagemap>
-------------
日历:datebox
-----------------分页---------------
paging组件用于将一段很长的内容分成多个页面。例如, 假定有100个项目,每次显示20个项目,那么可以按如下方式使用 paging 组件。
<paging totalSize="100" pageSize="20"/>
-----------------------------
标题 (caption)是 caption 组件声明的。 caption 组件的所有子组件都会出现在 title 的右边。也可以指定为图片
<window title="Demo" border="normal" width="350px">
<caption>
<toolbarbutton label="More"/>
<toolbarbutton label="Help"/>
</caption>
</window>
closable="true":关闭window
以下是不关闭,点击后隐藏
<window closable="true" title="Detach on Close" border="normal" width="200px"
onClose="self.visible = false; event.stopPropagation();">
In this example, this window hides itself when the close button is clicked.
</window>
注意,必须调用event.stopPropagation()阻止Window.onClose()被调用。
sizable="true":这样用户可以拖曳边框来改变
window样式:
sclass="wndcyan"
sclass="popup"
sclass="modal"
默认为没有
-------------滚动窗口-------------------
contentType的一个典型应用是使一个 window变得可滚动。:
<window id="win" title="Hi" width="150px" height="100px" contentStyle="overflow:auto" border="normal">
This is a long line to spead over several lines, and more content to display.
Finally, the scrollbar becomes visible.
This is another line.
</window>
-------------窗口边框-------------------
<zk>
<style>
div.wc-embedded-dash {
padding: 2px; border: 3px dashed #aab;
}
</style>
<window title="My Window" border="dash" width="200px">
Hello, World!
</window>
</zk>
-----------消息框--------------------
if (Messagebox.show("Remove this file?", "Remove?", Messagebox.YES | Messagebox.NO, Messagebox.QUESTION) == Messagebox.YES) {
...//remove the file
}
alert("Wrong");
Messagebox.show("Wrong");
-----------文件上传对话框-------------
<window title="Fileupload Demo" border="normal">
<image id="image"/>
<button label="Upload">
<attribute name="onClick">{
Object media = Fileupload.get();
if (media instanceof org.zkoss.image.Image)
image.setContent(media);
else if (media != null)
Messagebox.show("Not an image: "+media, "Error",
Messagebox.OK, Messagebox.ERROR);
}</attribute>
</button>
</window>
------------------一次上传多个文件------------------------
如果你允许一次上传多个文件,可以按如下方式指定允许数字的最大值。
<window title="fileupload demo" border="normal">
<button label="Upload">
<attribute name="onClick"><![CDATA[{
Object media = Fileupload.get(5);
if (media != null)
for (int j = 0; j < media.length; ++j) {
if (media[j] instanceof org.zkoss.image.Image) {
Image image = new Image();
image.setContent(media[j]);
image.setParent(pics);
} else if (media[j] != null) {
Messagebox.show("Not an image: "+media[j], "Error",
Messagebox.OK, Messagebox.ERROR);
}
}
}]]></attribute>
</button>
<vbox id="pics"/>
</window>
fileupload组件:
<image id="img"/>
Upload your hot shot:
<fileupload onUpload="img.setContent(event.media)"/>
--------------------布局-------------------
borderlayout
:border="normal" 有边框
:border="none" 无边框(默认)
splittable 和collapsible 属性
若你想使你的布局组件可拆分(splittable),则可以将splittable属性设置为true。
此外,若你想使一个组件可折叠(collapsible),则可以将collapsible属性设置为true。
<vbox> :vbox组件用于创建垂直box。
<hbox> :hbox组件用于创建水平box。
************
<vbox>
等价与
<box orient="vertical">
**************
spacing属性:box控件组件之间的间隙控制
<vbox spacing="5em">
<textbox/>
<datebox/>
</vbox>
------------widths 和 heights 属性------------------
使用widths属性可以指定hbox每个元素(cell)的宽度,如下。
<hbox width="100%" widths="10%,20%,30%,40%">
<label value="10%"/>
<label value="20%"/>
<label value="30%"/>
分割效果:splitter
<hbox spacing="0" style="border: 1px solid grey" width="100%">
<vbox height="200px">
Column 1-1: The left-top box. To know whether a splitter
is collapsed, you can listen to the onOpen event.
<splitter collapse="after"/>
Column 1-2: You can enforce to open or collapse programming
by calling setOpen method.
</vbox>
<splitter collapse="before"/>
Column 2: Whether a splitter allows users to open or collapse
depending on the collapse attribue.
</hbox>
<menuitem label="" autocheck="true"/>:将autocheck属性设为true,这样当用户点击此菜单项目时checked属性就会被自动切换(toggled)。
----------------------------------
可以将其改变为当鼠标移动到菜单上方时它自动打开。将autodrop属性设为true即可实现。:
<menubar autodrop="true">
...
</menubar>
<splitter collapse="before"/>
collapse="none" 无折叠发生。
collapse="before" 当按下按键时,相同组件内的元素立即在分割器(splitter)前折叠起来,这样其宽度或高度将变为0。
collapse="after" 当按下按键时,相同组件内的元素立即在分割器(splitter)后折叠起来,这样其宽度或高度将变为0
-----------网格--------------
<columns id="cs" sizable="true">
sizable="true":可调整宽度
<grid width="300px" mold="paging" pageSize="4">
添加mold和pageSize属性分页
<paging id="pg" pageSize="4"/>:在任何处加上paging即和grid里的分页相同
sortDirection="ascending" :排序
separator:
使用orient属性,你可以指定一个垂直或水平的separator。默认为水平separator,即插入一条水平线。 而垂直的separator为插入一个空格。另外,space是默认为垂直方向的separator的一种变体型(variant)。
使用bar属性,你可以控制在组件间显示水平线还是垂直线。
使用spacing属性,你可以控制spacing的大小。
<separator spacing="20px"/>
<window>
line 1 by separator
<separator/>
line 2 by separator
<separator/>
line 3 by separator<space bar="true"/>another piece
<separator spacing="20px"/>
line 4 by separator<space bar="true" spacing="20px"/>another piece
</window>
toolbar有两种布局方向:horizontal 和 vertical。它们可以控制如何放置按钮。
-----------------列表框---------------------------
Listbox有两种模型:default和select。若使用了select,就会产生HTML的SELECT标签。
<listbox mold="select">...</listbox>:带滚动下拉
引用css文件:<style src="/my.css"/>
---------------弹出式窗口-----------------------
<window id="win" title="Hi!" border="normal" width="200px">
<caption>
<toolbarbutton label="Close" onClick="win.setVisible(false)"/>
</caption>
<checkbox label="Hello, Wolrd!"/>
</window>
<button label="Overlap" onClick="win.doOverlapped();"/>
<button label="Popup" onClick="win.doPopup();"/>
<button label="Modal" onClick="win.doModal();"/>
<button label="Embed" onClick="win.doEmbedded();"/>
<button label="Highlighted" onClick="win.doHighlighed();"/>
<zscript language="Java">
var1 = 123;
</zscript>
<zscript language="JavaScript">
var2 = 234;
</zscript>
${value} :赋值
----------自定义控件---------------
<?component name="button" extends="button" style="border:1px solid blue" label="用户权限"?>
<button onClick="check()"/>
使用getZScriptVariable方法来获得zscript中的定义的变量。
使用getZScriptClass和getZScriptMethod方法来获取定义在zscript中的类和方法
如果你想找到某个解释器,可以使用getInterpreter方法先获得解释器,就像下面一样:
page.getInterpreter("JavaScript").getVariable("some"); //interpreter for JavaScript
page.getInterpreter(null).getVariable("some"); //interpreter for default language
特殊字符替换
< 用 <来替换
> 用 >来替换
& 用 &来替换
" 用 "来替换
' 用 '来替换
<zscript>
<![CDATA[ ----- 用CDATA解释器
void myfunc(int a, int b) {
if (a < 0 && b > 0) {
//do something
}
]]>
</zscript>
--------------html里添加命名空间----------
<html xmlns:="http://www.w3.org/1999/xhtml"
xmlns:x="http://www.zkoss.org/2005/zul"
xmlns:zk="http://www.zkoss.org/2005/zk">
<body>hello word!</body>
</hmtl>
------------if unles-------
如果a为1,且b不为2 window 组件就会被创建。
<window if="${a==1}" unless="${b==2}">
...
</window>
------------Switch和Case-------
使用zk元素的switch和case属性,你可以控制ZK页面在一个变量等于某个特定值时才会被执行。
<zk switch="${fruit}">
<zk case="apple">
Evaluated only if ${fruit} is apple
</zk>
<zk case="${special}">
Evaluated only if ${fruit} equals ${special}
</zk>
<zk>
Evaluated only if none of the above cases matches.
</zk>
------------正则表达式---------
<zk switch="${fruit}">
<zk case="/ap*.e/">
Evaluate if the regular expression, ap*.e"., matches the switch condition.
</zk>
</zk>
------------和forEach一起使用---
<zk case="${each}" forEach="apple, orange">
等价于,
<zk case="apple, orange">
------------反复式流程
在下面的例子中,列表项目被创建了三次。每个项目的label分别为"Best", "Better" 和 "God",
<listbox>
<listitem label="${each}" forEach="Best, Better, God"/>
</listbox>
如果你有一个存放对象集合的变量,则可以直接为forEach属性指定它。例如,假如你有一个grades变量,如下。
<zscript>
grades = new String[] {"Best", "Better", "Good"};
</zscript>
然后可以使用forEach属性来迭代此变量。注意,你必须使用EL表达式来指定这个集合。
<listbox>
<listitem label="${each}" forEach="${grades}"/>
</listbox>
迭代(iteration)依赖于forEach属性指定值的类型。
如果是java.util.Collection,就会迭代集合(collection)的每个元素。
如果是java.util.Map,就会迭代map中的每个Map.Entry。
如果是java.util.Iterator,就会迭代迭代器(iterator)中的每个元素。
如果是java.util.Enumeration,就会迭代enumeration中的每个元素。
如果是Object[],int[],short[],byte[],char[],float[]或double[]被指定了,就会迭代数组(array)中的每个元素。
如果是null,什么也不会产生(被忽略)。
如果被指定的不是以上类型,相关元素仅被赋值(evaluated)一次,就好像一个集合只指定了一个单 独的项目。
each变量
在迭代中,一个变量被称为each,通过指定集合的项目被创建并且赋值。在上面的例子中,首次迭代中,each被赋值为"Best",然后是"Better",最后是"Good"。
注意each变量在EL表达式和zscript中都是可访问的。ZK将会保留以前定义的每个变量,并在迭代完每个元素后将其恢复。
-----------------隐含对象------------------
self :组件本身
page :页面,与self.page相同
event: 当前事件
----------------进程指令-------------------
你可以将page指令放置在XML文档的任何地方
<?page [id="..."] [title="..."] [style="..."] [language="xul/html"] zscriptLanguage="Java"]?>
----------------
component指令:
<?component name="mywindow" extends="window" class="MyWindow"?>
...
<mywindow>
...
</mywindow>
等价于下面的代码:
<window use="MyWindow">
...
</window>
----------------
<?import uri="/template/taglibs.zul" directives="taglib, xel-method"?>
----------------
<?link rel="alternate" type="application/rss+xml" title="RSS feed"
href="/rssfeed.php"?>
<?link rel="shortcut icon" type="image/x-icon" href="/favicon.ico"?>
<?link rel="stylesheet" type="text/css" href="~./zul/css/ext.css.dsp"?>
<window title="My App">
My content
</window>
-------------------
unless属性
unless="${ an-EL-expr }"
指定不为相关元素赋值(evaluate)的条件。换句话说,如果条件值为真(false),关联元素及其所有子元素会被忽略。
------------------
forEach属性
forEach="${an-EL-expr}"
forEach="${an-EL-expr},a-value"
有两种格式。第一种,你可以不使用逗号来指定一个值。通常为一个对象集合,这样关联元素可以依靠(against)集合中的每个对象重复被赋值。如果没有指定或为空,此属性会被忽略。如果没有集合对象被指定,仅会被赋值一次就好像有一个单元素的集合被指定。
第二种,你可以指定一个列表,使用逗号分隔各项目。然后,对于列表中的每个值,相关联的元素会被重复执行(he associated element will be evaluated repeatedly against each value in the list)。
----------------------
forEachBegin属性
forEachBegin="an-interger"
forEachBegin="${an-EL-expr}"
被用于forEach 属性,指定迭代(iteration)开始处索引(从0开始)。如果没有指定,迭代会从第一个元素开始,即0。
如果forEachBegin大于或等于元素的数目,则不会发生迭代。
注:forEachBegin.index对于基本的集合,数组和其他类型是绝对的(forEachStatus.index is absolute with respect to the underlying collection, array or other type)。例如,如果
forEachBegin为5 ,forEachStatus.index的第一个值为5。
------------------------
forEachEnd属性
for EachEnd="${ an-EL-expr }"
被用于forEach 属性,指定迭代(iteration)结束处索引(包括此)(从0开始)。如果没有指定,迭代会在最后一个元素处结束。
如果forEachEnd大于或等于元素的数目,则迭代会在最后一个元素处结束。
------------------------
<div fulfill="b1.onClick, b2.onOpen"
onFulfill="Components.wireVariables(self, controller)">
...
</div>
------------------------
forward 属性
forward="target_event_expr"
forward="oringal_event=target_event_expr"
这里target_event_expr 是一个事件表达式。事件表达式被用于为一个组件指定事件。可以使用下面格式中的一个:
event-name
target-id.event-name
id1/id2/id3.event-name
${el-expr}.event-name
此属性用将目标组件一个事件以其他事件名称跳转至另一个组件。这就是所谓的跳转条件(forward condition)。
例如,你可以将button的onClick事件跳转至window,如下:
<window id="w" use="MyWindow">
...
<button lable="Submit" forward="onClick=w.onOK"/>
</window>
------------------------------
<window border="normal" width="100px">
<vbox id="result">
</vbox>
<zscript><![CDATA[
String[] s = {"this is 9", "this is ten more to show",
"this framework", "performance is everything"};
for (int j = 0; j < s.length; ++j) {
Label l = new Label(s[j]);
l.maxlength = 9;
l.hyphen = true;
l.parent = result;
}
]]></zscript>
</window>
------------------------------
orient:控制布局为横向或纵向。
例如:orient="vertical"
-------------单选按钮和单选按钮组--------------
<radiogroup onCheck="alert(self.selectedItem.label)">
<radio label="Apple"/>
<radio label="Orange"/>
<radio label="Banana"/>
</radiogroup>
----------------图像------------------
<imagemap src="/img/sun.jpg" onClick="alert(event.x + ", " +event.y)"/>
等价于:
通过为imagemap然后,组件添加area子组件,开发人员可以代替使用应用程序本身处理坐标的方法。
<imagemap src="/img/sun.jpg" onClick="alert(event.area)">
<area id="First" coords="0, 0, 100, 100"/>
<area id="Second" shape="circle" coords="200, 200, 100"/>
</imagemap>
-------------
日历:datebox
-----------------分页---------------
paging组件用于将一段很长的内容分成多个页面。例如, 假定有100个项目,每次显示20个项目,那么可以按如下方式使用 paging 组件。
<paging totalSize="100" pageSize="20"/>
-----------------------------
标题 (caption)是 caption 组件声明的。 caption 组件的所有子组件都会出现在 title 的右边。也可以指定为图片
<window title="Demo" border="normal" width="350px">
<caption>
<toolbarbutton label="More"/>
<toolbarbutton label="Help"/>
</caption>
</window>
closable="true":关闭window
以下是不关闭,点击后隐藏
<window closable="true" title="Detach on Close" border="normal" width="200px"
onClose="self.visible = false; event.stopPropagation();">
In this example, this window hides itself when the close button is clicked.
</window>
注意,必须调用event.stopPropagation()阻止Window.onClose()被调用。
sizable="true":这样用户可以拖曳边框来改变
window样式:
sclass="wndcyan"
sclass="popup"
sclass="modal"
默认为没有
-------------滚动窗口-------------------
contentType的一个典型应用是使一个 window变得可滚动。:
<window id="win" title="Hi" width="150px" height="100px" contentStyle="overflow:auto" border="normal">
This is a long line to spead over several lines, and more content to display.
Finally, the scrollbar becomes visible.
This is another line.
</window>
-------------窗口边框-------------------
<zk>
<style>
div.wc-embedded-dash {
padding: 2px; border: 3px dashed #aab;
}
</style>
<window title="My Window" border="dash" width="200px">
Hello, World!
</window>
</zk>
-----------消息框--------------------
if (Messagebox.show("Remove this file?", "Remove?", Messagebox.YES | Messagebox.NO, Messagebox.QUESTION) == Messagebox.YES) {
...//remove the file
}
alert("Wrong");
Messagebox.show("Wrong");
-----------文件上传对话框-------------
<window title="Fileupload Demo" border="normal">
<image id="image"/>
<button label="Upload">
<attribute name="onClick">{
Object media = Fileupload.get();
if (media instanceof org.zkoss.image.Image)
image.setContent(media);
else if (media != null)
Messagebox.show("Not an image: "+media, "Error",
Messagebox.OK, Messagebox.ERROR);
}</attribute>
</button>
</window>
------------------一次上传多个文件------------------------
如果你允许一次上传多个文件,可以按如下方式指定允许数字的最大值。
<window title="fileupload demo" border="normal">
<button label="Upload">
<attribute name="onClick"><![CDATA[{
Object media = Fileupload.get(5);
if (media != null)
for (int j = 0; j < media.length; ++j) {
if (media[j] instanceof org.zkoss.image.Image) {
Image image = new Image();
image.setContent(media[j]);
image.setParent(pics);
} else if (media[j] != null) {
Messagebox.show("Not an image: "+media[j], "Error",
Messagebox.OK, Messagebox.ERROR);
}
}
}]]></attribute>
</button>
<vbox id="pics"/>
</window>
fileupload组件:
<image id="img"/>
Upload your hot shot:
<fileupload onUpload="img.setContent(event.media)"/>
--------------------布局-------------------
borderlayout
:border="normal" 有边框
:border="none" 无边框(默认)
splittable 和collapsible 属性
若你想使你的布局组件可拆分(splittable),则可以将splittable属性设置为true。
此外,若你想使一个组件可折叠(collapsible),则可以将collapsible属性设置为true。
<vbox> :vbox组件用于创建垂直box。
<hbox> :hbox组件用于创建水平box。
************
<vbox>
等价与
<box orient="vertical">
**************
spacing属性:box控件组件之间的间隙控制
<vbox spacing="5em">
<textbox/>
<datebox/>
</vbox>
------------widths 和 heights 属性------------------
使用widths属性可以指定hbox每个元素(cell)的宽度,如下。
<hbox width="100%" widths="10%,20%,30%,40%">
<label value="10%"/>
<label value="20%"/>
<label value="30%"/>
分割效果:splitter
<hbox spacing="0" style="border: 1px solid grey" width="100%">
<vbox height="200px">
Column 1-1: The left-top box. To know whether a splitter
is collapsed, you can listen to the onOpen event.
<splitter collapse="after"/>
Column 1-2: You can enforce to open or collapse programming
by calling setOpen method.
</vbox>
<splitter collapse="before"/>
Column 2: Whether a splitter allows users to open or collapse
depending on the collapse attribue.
</hbox>
<menuitem label="" autocheck="true"/>:将autocheck属性设为true,这样当用户点击此菜单项目时checked属性就会被自动切换(toggled)。
----------------------------------
可以将其改变为当鼠标移动到菜单上方时它自动打开。将autodrop属性设为true即可实现。:
<menubar autodrop="true">
...
</menubar>
<splitter collapse="before"/>
collapse="none" 无折叠发生。
collapse="before" 当按下按键时,相同组件内的元素立即在分割器(splitter)前折叠起来,这样其宽度或高度将变为0。
collapse="after" 当按下按键时,相同组件内的元素立即在分割器(splitter)后折叠起来,这样其宽度或高度将变为0
-----------网格--------------
<columns id="cs" sizable="true">
sizable="true":可调整宽度
<grid width="300px" mold="paging" pageSize="4">
添加mold和pageSize属性分页
<paging id="pg" pageSize="4"/>:在任何处加上paging即和grid里的分页相同
sortDirection="ascending" :排序
separator:
使用orient属性,你可以指定一个垂直或水平的separator。默认为水平separator,即插入一条水平线。 而垂直的separator为插入一个空格。另外,space是默认为垂直方向的separator的一种变体型(variant)。
使用bar属性,你可以控制在组件间显示水平线还是垂直线。
使用spacing属性,你可以控制spacing的大小。
<separator spacing="20px"/>
<window>
line 1 by separator
<separator/>
line 2 by separator
<separator/>
line 3 by separator<space bar="true"/>another piece
<separator spacing="20px"/>
line 4 by separator<space bar="true" spacing="20px"/>another piece
</window>
toolbar有两种布局方向:horizontal 和 vertical。它们可以控制如何放置按钮。
-----------------列表框---------------------------
Listbox有两种模型:default和select。若使用了select,就会产生HTML的SELECT标签。
<listbox mold="select">...</listbox>:带滚动下拉
引用css文件:<style src="/my.css"/>
---------------弹出式窗口-----------------------
<window id="win" title="Hi!" border="normal" width="200px">
<caption>
<toolbarbutton label="Close" onClick="win.setVisible(false)"/>
</caption>
<checkbox label="Hello, Wolrd!"/>
</window>
<button label="Overlap" onClick="win.doOverlapped();"/>
<button label="Popup" onClick="win.doPopup();"/>
<button label="Modal" onClick="win.doModal();"/>
<button label="Embed" onClick="win.doEmbedded();"/>
<button label="Highlighted" onClick="win.doHighlighed();"/>
发表评论
-
struts2和struts1的区别
2010-02-03 16:36 1034Struts1: action对象只有一个,不管谁去 ... -
Struts2.0学习笔记(一)命名空间和.xml文件配置
2010-02-03 16:31 1753首先要说声对不起,感谢关注我博客的朋友。近期因为换工 ... -
动态 Table 添加删除行
2009-07-23 13:55 2847<html> <head> ... -
js 电子邮件验证
2009-07-17 10:24 2375<html> <title>aaa&l ... -
zk框架 特殊字符的替换方式
2009-04-27 15:15 1255特殊字符替换: < 用 < ... -
ZK框架 鼠标移动事件 & 移动在文本上显示信息
2009-04-23 14:06 3322例如一个超链接:在点击之前鼠标移动到连接上显示相应信息; 方法 ... -
js 最实用的一些操作
2009-04-01 13:58 12231. oncontextmenu="window.e ... -
Ajax状态值大全
2009-03-12 15:33 17740**:未被始化 1**:请求收到,继续处理 2**:操作 ... -
js 事件大全
2009-03-09 09:43 952一般事件 事件 浏览器支持 描述 onClick IE3|N ... -
汉洛塔算法
2008-12-03 16:21 1396private void MoveItem(int n, ... -
经典八皇后算法
2008-12-02 12:06 1681using System; using System.Data ... -
js 数字验证
2008-11-07 17:32 1154以下代码可直接复制使用: <SCRIPT LANGUAG ... -
实例 数组 广义表
2008-10-14 11:42 11351、 void RSh(int A[n],int k)//把数 ... -
数据结构四、串
2008-10-06 10:48 1990实例: void String_Reverse(Stringt ... -
数据结构三、栈与队列
2008-09-26 11:39 989基础实例:3.1 typedef stru ... -
数据结构二、线性表
2008-09-25 13:33 1206基础实例:2.1 Status DeleteK(SqList ... -
Web打印预览后 弹出窗口无法关闭
2008-09-23 11:17 4688jatoolsPrinter:打印控件出现了一个问题。这 ... -
数据结构一、基础实例
2008-09-22 17:58 939基础的数据结构实例: 1.1 void print_desc ... -
免费Web打印控件
2008-09-22 17:50 7400我现在的项目中有打印的模块,用的是一个免费的打印控件。 ... -
计算机 毕业论文
2008-09-10 18:06 1701自考毕业的时候为这篇论文可真是煞费脑筋啊,老师说了,就最普通的 ...
相关推荐
【标题】"ZK Scope 常用方法与结果" 在深入探讨ZK Scope的常用方法和结果之前,首先需要了解ZK是什么。ZK(ZK Framework)是一个开源的Java Web开发框架,专门用于构建富客户端用户界面,尤其是那些基于浏览器的...
ZK 是一个基于 Java 的轻量级Web框架,专门用于构建富客户端的Web应用程序。它提供了丰富的用户界面组件和事件处理机制,使得开发者能够轻松创建交互式的Web应用。本篇文章将深入探讨ZK框架的基本概念、开发环境的...
**六、ZK常用功能讲解** 1. **页面文本框校验**:使用`constraint`属性进行客户端验证,或者在Java代码中进行服务器端验证。 2. **ZUL页面与Window类的交互**:通过`use`属性引用自定义的Window类,利用`on+event ...
常用的方法有`create()`、`exists()`、`getData()`、`getChildren()`以及`setData()`等。 7. **集群配置**:如果需要在多台机器上搭建ZooKeeper集群,需要在每台机器的`zoo.cfg`中配置相应的服务器列表,并确保数据...
2. **eclipse**:指的是Eclipse IDE,它是Java开发者常用的一款开发工具,通过插件机制可以扩展其功能,支持多种编程语言和框架,包括我们的ZK。 3. **jar**:Java Archive,是Java平台的标准归档格式,通常包含类...
MVC(Model-View-Controller)和MVVM(Model-View-ViewModel)是现代Web应用常用的两种设计模式。ZK支持这两种模式,并提供了丰富的组件和工具来简化模式的实现。书中通过实例演示了如何在ZK中实现数据绑定、事件...
4. Visual C++环境:开发者可能使用Visual C++来编辑、编译和调试源代码,这是Windows平台上常用的C++开发工具。 5. 文件打包和加密:"zk.sea"文件可能是使用特定打包工具加密过的,用于保护源代码或数据的安全。 ...
此外,Spring MVC作为Spring的一部分,是构建Web应用的常用方式,它将请求处理、视图解析和业务逻辑分离,增强了代码的可测试性和可维护性。在这个项目中,Spring可能还被用来整合其他组件,如与Hibernate的集成,...
Grid是ZK中常用的表格组件,用于展示二维数据。它支持各种操作,如排序、分页、选择和编辑等。在ZK Grid中,我们可以利用`<template>`标签实现数据的自定义显示,这在处理嵌套数据时非常有用。 三、嵌套数据的显示 ...
这里需要注意的是,在ZScript中确实不直接使用JavaServer Pages (JSP) 中常用的EL(Expression Language)表达式。这是因为ZScript的设计理念在于提供一种更高级别的抽象层,使得开发者可以直接使用ZScript语法来...
在单片机应用中,可能由于内存限制,字库并不包含所有的汉字,而是选取常用的一部分。这个文件很可能是这种定制字库的代码文件,包含每个汉字的二进制表示,用于程序内部处理汉字显示。 学习和理解字库代码提取涉及...
ZK开发的必用工具,值得一用对大家,其中有一些常用的相关方法与接口
ZK框架也支持MVC(Model-View-Controller)设计模式,这是一种常用的软件架构模式,它将应用程序分为三个主要部分:模型(Model)、视图(View)和控制器(Controller)。 - **模型(Model)**:负责管理应用程序的数据,...
建筑工程常用表格2021C22-6-3_世纪大道工业供水(ZK2+000-ZK3+000).xls
建筑工程常用表格2021C22-6-3_世纪大道工业供水(ZK1+154-ZK2+000).xls
建筑工程常用表格2021C22-6-1_世纪大道(ZK1+154-ZK2+000)给水管道安装.xls
建筑工程常用表格2021C22-6-1_世纪大道工业供水(ZK2+000-ZK3+000)给水管道安装.xls
最常用的容器组件之一,可以包含其他任何类型的组件。 - **示例代码**: ```java // 创建一个Div实例 Div div = new Div(); div.appendChild(new LabelElement("这是一个Div容器")); ``` ##### Groupbox 用于...