ZK Web 框架 6.0 发布:新型数据绑定系统

  • Kostis Kapelonis
  • 吴宇

2012 年 3 月 31 日

话题:JavaWeb框架语言 & 开发架构

Potix,这家提供ZK框架的公司最近发布了该基于 Java 的 Ajax Web 应用框架的6.0 版。ZK 是一款开源 Java 框架,使得开发者能够基于 Ajax(无需编写任何 JavaScript)来开发丰富的互联网应用。除了提供样例演示外,公司官方网站还罗列了几个现实生活中使用 ZK 的应用。

Google Web Toolkit采用的方式类似,ZK 抽象了所有 JavaScript 和 HTML,开发者只需关注运行在服务器端的面向业务逻辑的 Java 代码即可。这可以通过实现一个在服务器端的事件引擎和一个在客户端(Web 浏览器)的 JavaScript 来达到。按这种方式,服务器端数据和客户端呈现之间的同步完全是自动的。开发者可以用自己熟悉的桌面框架(比如 Swing)事件模型来编写一个完整的应用。

这次最新版本中的改变包括:

  • 遵循 MVVM 模式的新型“ZK 绑定”系统
  • 运行在服务器端的 jQuery/CSS 3 风格选择器
  • 从 jQuery 1.4.x 升级到 1.6.x(性能提高)
  • 高级模板
  • 面向 Servlet 3 异步处理的 ZK Comet 支持
  • 新组件(而弃用老组件)
  • 升级到 Java 5
  • 新的默认主题选择

其中最重要的一个改变是新型数据绑定系统。ZK 遵循Model View ViewModel模式(MVVM),这里的视图模型(ViewModel)层负责将模型(Model)中的值转化为视图(View),并且当视图被用户改变时,将其更新回模型。图形化用户界面由标记语言声明,该语言完全和模型(Model)中包含的数据分离。在 ZK 框架中被使用的标记称作ZK 用户界面标记语言(ZUML),而真正的业务逻辑驻留在 Java 代码中。这里的一大原则就是 ZUML 能够被非编程人员编辑,这样就可以并行进行用户界面(UI)和 Java 代码的开发,从而提高效率。该模式并非 ZK 专属,其它大家熟知的例子包括 Mozilla 的XUL和 Miscrosoft 的XAML。ZK 也支持通过ZK Richlets,使用纯 Java 来创建用户图形界面(GUIs)。

“ZK 绑定”支持EL2.2 表达式,使得可配置数据能够在 ZUML 图形化组件和服务器端 Java 对象之间传输(单向或双向)。直接支持在CDISeamSpring beans 上的绑定。由于升级到 Java 5,允许在服务器端代码中使用泛型和类型安全。需要说明的是,对那些需要 ZK 5 的老式绑定系统,或目前还不想升级的用户来说,老版本仍然提供支持。

另一个要介绍的新特性是提供了面向服务器端Java 代码的jQuery 风格选择器。该功能给开发者提供了一种简洁又方便的方式来访问服务器端组件。下面是从ZK 文档中直接拿来的一个样例:

Window win;
 
// returns all components with id "myId" under the Window win. (including itself)
Selectors.find(win, "#myId");
 
// returns all components whose .getLabel() value is "zk" (if applicable)
Selectors.find(page, "[label='zk']");
 
// you can assemble the criteria:
// returns all labels, whose parent is a window of id "win", and whose value is "zk"
Selectors.find(page, "window#win > label[value='zk']");

最后,ZK 6.0 利用了 Servlet 3.0 规范中对异步请求的支持。这意味着可以使用每个请求对应一个线程(Thread-Per-Request)的实现方式,而非每个连接对应一个线程(Thread-Per-Connection)。由于线程在不需要时可以更频繁的循环使用,性能就会得到提高。

ZK 6.0 的下载包含多个版本,这由其许可决定。更多的信息可以通过参考文档Javadocs来了解。源代码在GitHub上可以得到。升级指导文档也已经可用。

查看英文原文:ZK Web Framework 6.0 Released: New Data Binding System

JavaWeb框架语言 & 开发架构