个人觉得,GWT的客户端表现并不是Gwt这个项目最关心的方向,所以要做出表现丰富的界面,要花去不少心思,当你为做一个“可排序的Grid”被搞得焦头烂额时,想想EXT,DOJO,只有艳羡地分了。
GWT-Ext 是sanjiv.jivan为了丰富GWT的客户端表现而贡献的开源项目。项目结合了当前客户端表现和用户体验都相当完善的Ext,提供了一种操作性很强的RIA开发方式。
作者应该花了不少心思在项目上,更新很频繁,大概不到1个月就有新的版本问世,目前项目的版本为GWT-Ext 0.9.3,是 Ext 1.1.1 和 GWT 1.4 Final 的结合,在 Ext 方面实现了大多数常用的控件,如Grid、Tree、Form、TabPanel等等。具体实现效果可以查看项目中的 Showcase Demo 。
以下结合一个例子来演示一下如何使用GWT-Ext 做实际开发。
一定要认真阅读项目中的 GettingStarted ,下面起初的几段其实就是该文的中文译本。
一、在Gwt项目中集成GWT-Ext
1.下载gwtext-0.9.3.zip,之后解压,将其中的 gwtext.jar 附加到当前GWT项目(Tree)的BuildPath中。
2.下载ext-1.1.1.zip (注意:暂时还不支持最新的2.0版本),将的ext-all.js、ext-core.js以及resources和adapter两个目录拷贝到module的public中的js/ext位置。对Ext熟悉的话,可以只拷贝需要的文件而不必载入所有的资源文件。
3.修改GWT项目中module的html页面,添加Ext资源,修改后的html页面可能是这样:
html代码
- <html>
- <head>
-
- <title>Wrapper HTML for Treetitle>
-
- <meta name='gwt:module' content='showcase.Tree'/>
-
- <link type="text/css" rel='stylesheet' href='Tree.css'/>
-
- <link rel="stylesheet" type="text/css" href="js/ext/resources/css/ext-all.css"/>
- <link rel="stylesheet" type="text/css" href="js/ext/resources/css/xtheme-aero.css" />
- <script type="text/javascript" src="js/ext/adapter/yui/yui-utilities.js">script>
- <script type="text/javascript" src="js/ext/adapter/yui/ext-yui-adapter.js">script>
- <script type="text/javascript" src="js/ext/ext-all.js">script>
-
- head>
-
- <body>
-
- <script language="javascript" src="gwt.js">script>
-
- <iframe id="__gwt_historyFrame" style="width:0;height:0;border:0">iframe>
-
- body>
- html>
4.编辑项目的Tree.gwt.xml文件,添加以下
xml 代码
- <inherits name='com.gwtext.GwtExt'/>
通过以上步骤,你就可以写接近Ext功能的客户端界面了,同时也具有了Gwt的各种开发优势了,比如Java方式开发,清晰的RPC(这点尤其是在客户端需要获取服务器端数据信息时尤其方便)等等。
二、实例
下面我们就编写Showcase Demo 中的Tree节点下的Two Trees Drag & Drop,例子实现的是两个Tree中节点的任意拖放(再次感叹Ext的丰富表现)。
Tree.java代码如下,可直接拷贝到查看效果。
java 代码
注意:例子中需要的两个数据文件需放置于public目录,熟悉Ext的应该很清楚。
编译后执行的效果如下图:
以上示例只是将该种开发方式的流程顺了一下,窥一斑以示全貌,Ext各种丰富的表现都可以实现。闲下来,再写一下将数据提供(其实就是一些多维数据而已)方式改为RPC,这样开发流程就完整了。
可以下载示例程序运行一下,证明我没骗你
- 描述: 示例的运行效果
- 大小: 73.3 KB
分享到:
相关推荐
GWT (Google Web Toolkit) 是一个开源的Java开发框架,用于构建和部署富互联网应用程序(RIA)。它允许开发者使用Java语言编写客户端代码,然后由GWT编译器将其转换为优化过的JavaScript,可以在各种浏览器上运行。...
GWT 是一个用于构建富互联网应用程序(RIA)的 Java 开发框架,允许开发者使用 Java 语言编写客户端代码,然后自动编译为优化过的 JavaScript。 在 GWT-Ext-Tree 中,核心知识点主要包括以下几个方面: 1. **树形...
通过上述步骤,开发者能够在 Java 环境下进行 GWT-Ext 应用的开发和调试,从而提高开发效率。GWT-Ext 的出现,使得开发者可以在熟悉的 Java 语言环境中,利用 ExtJs 的丰富界面组件,轻松构建出具有高级交互特性的...
GWT是一个开源的开发工具,允许开发者使用Java语言来编写客户端的Web应用程序,然后将其编译为优化过的JavaScript代码,以实现高性能的富互联网应用(RIA)。而Ext Js是一个JavaScript库,提供了丰富的用户界面组件...
- **Eclipse 和 Cypal Studio**:为了搭建 GWT-Ext 开发环境,通常推荐使用 Eclipse 集成开发环境,并安装 Cypal Studio 插件,它简化了 GWT 项目的创建、调试和部署过程。 - **配置 GWT 和 Java VM**:设置 GWT ...
压缩包文件"gwtext-2.0.3"可能包含的是Gwt-Ext的一个特定版本,2.0.3,这个版本可能包含了库文件、示例代码、文档等资源,供学习者参考和使用。在这个版本中,开发者可以找到各种UI组件的示例,如表格、面板、按钮、...
GWT是一种由Google开发的开源JavaScript框架,它允许开发者使用Java语言来编写前端应用程序,并自动编译成优化的JavaScript代码,提高了开发效率和性能。EXT则是一个用于构建富互联网应用(Rich Internet ...
GWT是Google推出的一个用于开发富互联网应用程序(RIA)的开放源代码框架,它允许开发者使用Java语言编写客户端应用,然后自动编译成JavaScript。EXT-GWT则是基于GWT的组件库,提供了丰富的用户界面元素,让开发者...
GWText是一个基于Google Web Toolkit (GWT) 和EXT GWT (GXT) 框架的开源项目,用于构建富互联网应用程序(Rich Internet Applications, RIA)。这个“gwtext编写的小系统”是一个示例项目,旨在帮助初学者理解如何...
标题 "GWT+EXT+STRUTS2+Eclipse完整范例.rar" 提示我们这是一个包含一个集成开发环境Eclipse的项目,该项目集成了Google Web Toolkit (GWT), EXT JS 和Struts2框架。描述 "整合 GWT EXT STRUTS2 Eclipse 范例" 明确...
《Developing with ExtGWT: Enterprise RIA Development》是一本针对ExtGWT框架的专业指导书籍,旨在帮助Java开发者快速掌握并运用ExtGWT进行企业级富互联网应用(RIA)的开发。本书由Grant K. Slender撰写,全书共...
Google Web Toolkit(GWT)应运而生,它是Google推出的一个用于构建Ajax应用的开源开发包,主要特点是允许开发者使用Java语言进行Ajax应用的编写。 选择GWT的原因在于,Java作为企业级应用的主流语言,拥有成熟的...
EXT-GWT,全称为Ext GWT,是Sencha公司开发的一个强大的Java库,用于构建富互联网应用程序(RIA)。GXT是EXT-GWT的扩展,它提供了更多组件、样式和功能,使得开发者能够创建出与桌面应用相媲美的用户体验。GXT 2.2.3...
2. **企业级RIA开发**:书中的实践方法论针对的是希望使用经过行业验证的工具进行企业级RIA开发的开发者。它强调了快速有效地掌握领先商业RIA工具和库的重要性。 3. **设置与环境**:首先,书中详细介绍了如何配置...
EXT-GWT,全称为Ext GWT,是Sencha公司推出的一款基于Java的开源富互联网应用程序(Rich Internet Application,RIA)开发框架。GXT是EXT-GWT的简称,它提供了丰富的用户界面组件,允许开发者用Java代码来构建复杂的...
本书旨在帮助Java开发者快速掌握如何使用Ext GWT框架开发企业级RIA(Rich Internet Application,富互联网应用)。 #### 二、主要内容 本书共约140页,主要涵盖了以下几个方面: 1. **入门指南**:首先介绍了如何...
Developing with Ext GWT Enterprise RIA Development