`

ZK常用资料整理

    博客分类:
  • zk
阅读更多

在一个页面中使用多种脚本语言 
<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 

特殊字符替换 
<     用   &lt;来替换 
>     用   &gt;来替换 
&     用   &amp;来替换 
"     用   &quot;来替换 
'     用   &apos;来替换 


<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 + &quot;, &quot; +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();"/> 

分享到:
评论

相关推荐

    zk网页资料整理,都是些小案例

    zk small talks 页面整理,我在开发过程中参考的官网案例介绍,现整理成*.mht文件的形式,供大家参考,很实用.在遇到zk方面的问题可以加qq群:71714290交流。

    GD32F450zk开发板资料

    通过这些资料,开发者可以全面了解GD32F450zk开发板的硬件特性,学习如何使用GD32系列微控制器进行软件开发,以及如何选择合适的GigaDevice产品,同时还能探索和实践物联网操作系统 LiteOS 的集成与应用。

    zk 6 学习资料

    ZK 6 学习资料是一套全面的资源集合,专为想要深入理解和掌握ZK 6框架的开发者设计。ZK是一个Java为基础的用户界面(UI)框架,它简化了构建富互联网应用程序(RIA)的过程,特别是对于企业级应用。这个压缩包包含了...

    ZK资料学习zk框架的助手

    本资料包是针对ZK框架的学习资源,旨在帮助用户深入理解和掌握ZK在实际应用中的使用。 ZK的核心设计理念是“简单、快速、正确”,它采用类Zookeeper协议,提供了一个高可用、高性能、分布式的数据存储和通信机制。...

    zk代码整理文档.txt

    zk代码整理文档.txt

    zk 学习资料 第一部分

    zk 学习资料 第一部分 zk 学习资料 第一部分

    zk 学习资料 第二部分

    zk 学习资料 第二部分

    ZK Scope 常用方法与结果

    【标题】"ZK Scope 常用方法与结果" 在深入探讨ZK Scope的常用方法和结果之前,首先需要了解ZK是什么。ZK(ZK Framework)是一个开源的Java Web开发框架,专门用于构建富客户端用户界面,尤其是那些基于浏览器的...

    zk入门.web框架

    **六、学习资料** 除了本文提供的信息外,还有更多官方文档、教程和示例代码可供参考,以深入了解ZK框架的各个方面。 **七、学习心得** 学习ZK框架需要理解组件模型、事件处理机制以及ZScript与Java代码的交互...

    Ajax框架 ZK文档资料

    **Ajax框架ZK详解** Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。ZK是一个基于Java的Ajax框架,它为开发人员提供了丰富的用户界面组件和交互式应用,...

    zk开发全套资料(插件,开发手册,jar包,笔记和程序事例)

    这套zk开发全套资料包含了ZK开发所需的多个重要组成部分,下面将逐一详细介绍这些资源及其在ZK开发中的作用。 1. **插件**:ZK的插件可以扩展其功能,例如数据绑定、图表生成、报表工具等。开发者可能需要使用这些...

    zkframework Eclipse插件 zkstudio ZK Studio

    **ZK Framework与Eclipse插件ZK Studio详解** ZK Framework是一款强大的Java Web开发框架,专注于构建富客户端用户界面。它提供了一种基于事件驱动和组件模型的编程方式,使得开发者无需处理复杂的JavaScript和HTML...

    ZK32-1_library_zk_thinkkrz_zk32+9999zk.com_

    ZK32通常指的是ZK Software公司的ZK TEchnology Kernel 32,这是一个专为开发生物识别设备(如指纹识别)应用的SDK(Software Development Kit)。Thinkkrz可能是ZK32的一个版本或者与之相关的开发团队或项目名,而...

    ZK+spring+hibernate的整合

    《ZK+Spring+Hibernate整合详解》 ZK、Spring和Hibernate是Java开发中的三大重要框架,它们分别在用户界面、依赖注入与事务管理、持久层操作方面发挥着关键作用。将这三者进行整合,可以构建出高效、稳定且易于维护...

    zk框架zk7api

    zk后台api很全的,对于学习ZK很有用的。

    ZK入门学习资料:ZK实例学习

    《ZK入门学习资料:ZK实例学习》 Zookeeper(简称ZK)是一个开源的分布式协调服务,由Apache基金会开发。它为分布式应用提供高效且可靠的命名服务、配置管理、集群同步、领导者选举等核心功能。在分布式系统中,...

    ZK安装 ZK入门 开发 讲解 共3个pdf

    ZK,全称为ZK Framework,是一个开源的Java Web组件库和事件驱动框架,主要用于构建富客户端用户界面。ZK以其独特的服务器端组件模型和事件处理机制,为开发者提供了便捷的用户界面开发体验,尤其在企业级应用中广泛...

    ZK 开发手册(带目录版本)

    这些资料的整理和发布,旨在让更多人了解和使用ZK框架。 在Web程序和AJAX技术背景下,ZK项目的诞生和演进是为了解决传统Web应用在处理现代应用复杂性方面的不足。ZK的开发手册提供了必要的基础知识和指导,使得...

    zk框架入门学习

    zk框架的入门介绍,刚开始学习和接触zk框架的伙伴可以看看,不错的资料

Global site tag (gtag.js) - Google Analytics