Google Web Toolkit

来自开放百科 - 灰狐
2012年10月29日 (一) 08:4884.20.13.68 (讨论)的版本

跳转到: 导航, 搜索
Wikipedia-35x35.png 您可以在Wikipedia上了解到此条目的英文信息 Google Web Toolkit Thanks, Wikipedia.
Gwt-100x100.png

Google Web Toolkit (GWT) 允许开发人员使用 Java 编程语言快速构建和维护复杂但性能高的 JavaScript 前端应用程序,从而降低了开发难度,尤其是与 Eclipse Google 插件结合使用时,优势更明显。

有了 Google Web Toolkit (GWT),可以使用 Java 编程语言编写 AJAX 前端,然后 GWT 会交叉编译到优化的 JavaScript 中,而 JavaScript 可以自动在所有主要浏览器上运行。在开发过程中,您可以用 JavaScript 按照您习惯的“编辑 - 刷新 - 查看”这种不变的循环快速反复,这样做还带来一个好处,即能够逐行调试并单步执行您的 Java 代码。准备好进行部署后,GWT 会将 Java 源代码编译到优化且独立的 JavaScript 文件中。使用 Google Web Toolkit 可以轻松地为现有网页或整个应用程序构建一个 Widget。

Pyjamas 是 Google Web Toolkit 的 Python 克隆 ?

目录

概述

采取 Apache 2.0 许可协议

GWT除了支持将应用Java语言开发的应用转化为Ajax应用,同时提供了更多的高级特性,下面是这些特性的简单描述。

  • GWT编译器

GWT编译器是GWT的核心,负责完成将Java代码翻译很Ajax内容的工作。GWT编译器能够翻译Java语言的大部分特性。包括支持Java语言中的基本类型、违例处理等,支持java.lang包和java.util 包中的绝大部分类和接口,支持正则表达式和序列化。

  • 跨平台支持

如果你使用GWT中提供的显示组件(比如Button)和组装组件(比如VerticalPanel),GWT编译生成的Ajax应用能够支持大部分的浏览器和操作系统,比如Internet Explorer、Firefox等,也能够支持Linux、Windows等不同操作系统。这是因为GWT最大限度的将这些控件翻译成浏览器内置的类型。比如Button类编译后生成的是标准HTML:<input type="button">。 GWT建议使用CSS修饰页面元素的显示效果。GWT的类中很少提供访问页面元素样式属性的方法,我们可以直接在CSS文件中通过对应的样式名称来设置页面元素的默认显示效果。比如使用 .gwt-Button { font-size: 150%; } 使用Button元素的默认显示效果。

  • 宿主模式(Hosted Mode)

宿主模式是指我们和没有转换为Ajax应用的GWT应用交互的状态。当我们开发和调试时,我们就一直处在宿主模式下。在这种情况下,Java虚拟机使用GWT内置的浏览器运行GWT应用编译后的class内容,因此能够提供"编码、测试、调试"过程的最佳速度。 我们可以运行com.google.gwt.dev.GWTShell启动宿主模式。

  • Web模式(Web Mode)

Web模式是指已经成功转化为Ajax应用的状态,这种状态下,我们已经开始通过Web方式来访问Ajax应用了。在Web模式下运行时,不再需要GWT工具包或者JVM的支持。

  • 命令行工具

GWT工具包中提供了几个非常适用的小工具来帮助我们更快的建立GWT应用开发环境:projectCreator、applicationCreator、junitCreator。

功能

  • 通过非常简单的 RPC 与服务器通信
  • 根据用户个人资料优化 JavaScript 脚本下载
RPC Plumbing Diagram
  • 跨项目重复使用 UI 组件
  • 使用其他 JavaScript 库和本机 JavaScript 代码
  • 轻松支持浏览器的后退按钮和历史记录
  • 高效地对应用程序进行本地化
  • 使用选择的开发工具提高生产力
  • 使用 JUnit 测试代码
  • 扩展或投稿 - Google Web Toolkit 是一种开源软件

Guide

[allen@centos gwt-linux-1.4.61]$ ./applicationCreator -out Huihoo com.huihoo.client.App

Created directory Huihoo/src
Created directory Huihoo/src/com/huihoo
Created directory Huihoo/src/com/huihoo/client
Created directory Huihoo/src/com/huihoo/public
Created file Huihoo/src/com/huihoo/App.gwt.xml
Created file Huihoo/src/com/huihoo/public/App.html
Created file Huihoo/src/com/huihoo/client/App.java
Created file Huihoo/App-shell
Created file Huihoo/App-compile

[allen@centos gwt-linux-1.4.61]$ cd Huihoo/

[allen@centos Huihoo]$ ls
App-compile  App-shell  src

[allen@centos Huihoo]$ ./App-compile

Output will be written into ./www/com.huihoo.App
Copying all files found on public path
Compilation succeeded
Hello GWT

file:///Huihoo/www/com.huihoo.App/App.html Awesome you should think of smoetihng like that

Tools

Games

Dude, right on there brotehr.

Examples

Comment-32x32.png

<discussion>characters_max=300</discussion>

分享您的观点
个人工具
名字空间

变换
操作
导航
工具箱