http://www.jtv.com.cn/html/jszx06.asp
GWT(http://code.google.com/webtoolkit)是Google Web Toolkit 的简写。它是google公司发布的基于java语言开发Web2.0应用的工具包。使用GWT开发web应用,只需要编写Java代码来构造传统的通过HTML来构造的web界面组件。而在与后台交互方面,GWT也实现了对ajax的封装。
我们可以使用任何java开发工具来编写基于GWT的java web应用代码。现在已经提供gwt开发便利性支持的开发工具有Eclipse、Intelij Idea等。java代码通过gwt自带的编译器编译完成后,将生成支持Internet Explorer、Mozilla、Opera、Safari等主流浏览器的JavaScript代码。
传统网页上的各种HTML组件在GWT上都有实现。HTML里面的onXxx事件在GWT里面是通过与java awt中事件\类似的方式来处理的。另外GWT也提供了布局管理器和一些常用的布局。通过这些功能,如同用java代码编写java界面程序一样,当我们打开最终的html,就能看到通过java界面设计器设计的的界面。传统网页设计中,要实现多级菜单、消息框、树形结构等常见控件,通常要编写大量的JavaScript代码并结合CSS来实现,而在GWT里面,只需要创建一个实例,再调用相关方法将文字和事件加上去就行了。
GWT开发分为web-mode和host-mode两种方式,分别对应产品发布模式和开发调试调试模式。web-mode调用GWTCompiler类将java代码编译为最终的javascript文件(实际是html文件,但html文件中只有几个html标签,内容大部分是javascript代码)。打开html文件就能开到通过java设计的界面。host-mode调用GWTShell类,将启动GWT内置的web服务器和web浏览器,用以调试应用,输出调试信息和堆栈信息。
GWT开发中必不可少的一个文件是.gwt.xml。GWT在将java代码转化为javascript时会根据该文件的配置来执行便宜过程。该文件大致格式如下:
<module>
<inherits name="com.google.gwt.user.User"/>
<entry-point class="com.jtv.gwt.client.MyApp"/>
<source path=“client"/>
<public path="public"/>
<servlet path="/cmdService"
class="com.jtv.gwt.server.CommandServiceImpl" />
</module>
其中:
Inherits指明继承模块,继承后可以共享资源,如js资源;必需项,内容是
"com.google.gwt.core.Core"或inherit自它的model的名称;
entry-point指明页面载入时要做什么;必需项,内容是EntryPoint实现类的全名;
source指明客户端代码的目录;默认是该xml所在目录下的client目录;
public指明公用文件的目录;默认是该xml所在目录下的public目录;
Servlet只是host-mode时用到,指明访问的后台servlet的别名以及全名。
GWT为方便客户端服务器交互性开发,封装了远程过程调用(RPC),即现有开发方式中的ajax。用GWT开发RPC应用,不用再考虑java对象的序列化和反序列化问题,GWT会自动将java类序列化为字符串传递到浏览器客户端,自动将浏览器客户端传回的字符串反序列化为java类的实例。RPC开发必须遵循如下约定:
1、两个接口:A继承自RemoteService并定义一个方法,B的命名和方法需要与A保持一致
A:X1XxxxService.xxxMethod(X2..)
B:voidXxxxServiceAsync.xxxMethod(X2..,AsyncCallback callback)
2、AsyncCallback类处理反馈数据
AsyncCallback.onSuccess(Object) 中的参数就是X1的实例。即
XxxxService.xxxMethod的返回值
3、Servlet继承自RemoteServiceServlet并实现A接口
应用开发完成并生成最终JavaScript代码后,用浏览器打开html文件,则会自动载入设计好的界面。界面载入的流程是这样的:
1 a.html载入后,其中的gwt.js根据meta标签确定当前html对应的gw的modelName等信息;
2 在当前界面插入一个Iframe,地址是modelName.nocache.html。该html只负责判断浏览器类型,并将它的url转向为具体浏览器对应的.cache.html文件;
3 .cache.html文件 "调用".gwt.xml中配置的EntryPoint的方法设定的操作,如添加界面控件、执行后台查询等;
4 当组件事件被用户触发后,或者直接处理或者与后台交互;
5 如果与后台交互,则将请求通过HttpRequest发送到servlet,servlet处理请求并返回结果;
6 AsyncCallback.onSuccess(Object)方法将返回结果展示给用户。
另外GWT还具备在java中书写JavaScript脚本($wnd,$doc)和java与javascript二者共享对象、互访成员变量的机制。
附记:当时写的文字更多的,主要是因为公司要搞测评,这是个整理到公司网站上的,实际的更多但是被我前几天删掉了。所以这更加说明要记录在网上,这样就不会说删除就删除了
分享到:
相关推荐
**GWT(Google Web Toolkit)简介** GWT,全称为Google Web Toolkit,是Google推出的一款开源的Java开发框架,主要用于构建高性能、跨浏览器的富互联网应用程序(Rich Internet Applications,简称RIA)。GWT允许...
8. **历史管理**:GWT的History API允许应用程序创建和管理URL片段,实现页面状态的导航,而无需刷新整个页面。 9. **单元测试**:GWT提供JUnit支持,允许在浏览器环境中进行客户端代码的单元测试。 10. **CSS和...
GWT,全称为Google Web Toolkit,是Google推出的一款开源JavaScript开发框架,允许Java开发者使用Java语言来编写Web应用。GWT通过编译器将Java代码转换为高效的JavaScript,从而在客户端浏览器上运行。这个“GWT入门...
#### 一、GWT简介及背景 - **GWT**(Google Web Toolkit)是一款由谷歌开发的开源框架,旨在帮助开发者利用Java编写高性能的Web前端应用。它通过将Java代码编译成JavaScript,使得开发者能够在不直接编写JavaScript...
8. **丰富的UI组件**:GWT提供了大量的预构建UI组件,如按钮、表单、表格等,这些组件可以方便地进行定制和组合。 9. **单元测试**:GWT提供了JUnit支持,使得开发者可以在服务器端进行客户端代码的单元测试。 10....
【GWT开发者手册】是为新入职员工提供GWT技术培训的文档,旨在让无GWT背景的JAVA开发者能在短时间内掌握GWT开发。本手册基于GWT版本gwt-windows-1.3.3,适用于熟悉JAVA语言和具有J2EE三层架构开发经验的WEB应用程序...
Gwt中文手册,GWt入门Gwt中文手册,GWt入门Gwt中文手册,GWt入门
#### 一、GWT简介 **Google Web Toolkit (GWT)** 是由Google推出的一款开源的Java开发框架,主要用于构建高度交互式的Web应用程序,特别是那些类似Google Maps和Gmail这样的AJAX应用。GWT的设计灵感来源于Java AWT...
GWT开发基础知识点 在本资源中,我们将讨论Google Web Toolkit(GWT)的基础知识点,包括GWT的安装、配置、编码基础和客户端代码编写等方面的内容。 GWT安装和配置 在Eclipse中添加GWT插件是使用GWT开发的第一步...
8. **拖放功能**:SmartGWT支持拖放操作,开发者可以了解如何启用和自定义拖放行为。 9. **响应式设计**:随着移动设备的普及,响应式设计变得越来越重要。DEMO可能包含了如何使组件适应不同屏幕尺寸的示例。 10. ...
GWT,全称为Google Web Toolkit,是Google推出的一款开源JavaScript开发框架,用于构建高性能的、客户端的Web应用程序。GWT允许开发者使用Java语言编写代码,然后自动编译为优化过的JavaScript,使得开发者能够利用...
#### 一、GWT特性简介 **1. 动态、可重用的UI组件** GWT 提供了一系列丰富的 UI 组件库,这些组件不仅功能强大而且高度可定制,使得开发者能够轻松地构建美观且交互性强的用户界面。每个 UI 组件都对应于 GWT 中的...
8. **优化生产代码**:在准备好发布应用时,GWT提供了一个编译器,将Java代码编译成高度优化的JavaScript,以实现最佳性能。 9. **处理部署**:最后,将编译后的JavaScript和其他必要的资源打包成WAR文件,然后部署...
**GWT 概述** GWT(Google Web Toolkit)是由Google开发的一款开源的JavaScript开发框架,主要用于构建高性能、跨浏览器的Web应用程序。GWT通过Java语言进行开发,并将Java代码编译成高效的JavaScript,使得开发者...
GWT,全称为Google Web Toolkit,是一个开源的Java框架,用于构建高性能、跨浏览器的Web应用程序。这本书《GWT 揭秘》显然深入探讨了GWT的内部机制和使用技巧,通过源代码来帮助读者更好地理解和应用这个强大的工具...
## GWT简介 Google Web Toolkit的核心理念是将Java的生产力引入到Web应用开发中。它提供了一套完整的工具链,包括IDE插件、编译器、调试器和丰富的UI组件库。GWT的出现解决了传统Web开发中AJAX技术带来的复杂性,...
GWT,全称为Google Web Toolkit,是一个开源的Java框架,用于构建高性能的、富交互式的Web应用程序。这个“GWT API.rar”压缩包包含了史上最全的GWT API文档,对于开发者来说是极其宝贵的资源,特别是在使用Java进行...
8. **单元测试**:GWT提供了JUnit支持,用于编写和运行客户端代码的单元测试,了解如何编写和运行这些测试。 9. **模块化开发**:GWT支持模块化开发,通过.gwt.xml文件定义模块,理解如何组织和管理项目模块。 10....
【GWT EXT 教程全集】是一份综合性的教程资源集合,主要涵盖了GWT(Google Web Toolkit)和EXT-GWT这两个技术领域的知识。GWT是Google推出的一个用于开发富互联网应用程序(RIA)的开放源代码框架,它允许开发者使用...
8. **编译与部署**:完成开发后,使用GWT编译器将Java代码编译为JavaScript,然后将生成的文件部署到Web服务器上供用户访问。 ### GWT的主要特性 1. **跨浏览器兼容**:GWT自动处理JavaScript的差异,使得应用能够...