GWT都有什么特性


Posted in 面试题 onDecember 02, 2016
GWT除了支持将应用Java语言开发的应用转化为Ajax应用,同时提供了更多的高级特性,下面是这些特性的简单描述。
1.GWT编译器
GWT编译器是GWT的核心,负责完成将Java代码翻译很Ajax内容的工作。GWT编译器能够翻译Java语言的大部分特性。包括支持Java 语言中的基本类型、违例处理等,支持java.lang包和java.util包中的绝大部分类和接口,支持正则表达式和序列化。
2.跨平台支持
如果你使用GWT中提供的显示组件(比如Button)和组装组件(比如VerticalPanel),GWT编译生成的Ajax应用能够支持大部分的浏览器和操作系统,比如Internet Explorer、Firefox等,也能够支持Linux、Windows等不同操作系统。这是因为GWT最大限度的将这些控件翻译成浏览器内置的类型。比如Button类编译后生成的是标准HTML:
GWT建议使用CSS修饰页面元素的显示效果。GWT的类中很少提供访问页面元素样式属性的方法,我们可以直接在CSS文件中通过对应的样式名称来设置页面元素的默认显示效果。比如使用 .gwt-Button { font-size: 150%; } 使用Button元素的默认显示效果。
3.宿主模式(Hosted Mode)
宿主模式是指我们和没有转换为Ajax应用的GWT应用交互的状态。当我们开发和调试时,我们就一直处在宿主模式下。在这种情况下,Java虚拟机使用GWT内置的浏览器运行GWT应用编译后的class内容,因此能够提供”编码、测试、调试”过程的最佳速度。
我们可以运行com.google.gwt.dev.GWTShell启动宿主模式。
4.Web模式(Web Mode)
Web模式是指已经成功转化为Ajax应用的状态,这种状态下,我们已经开始通过Web方式来访问Ajax应用了。
在Web模式下运行时,不再需要GWT工具包或者JVM的支持。
5.命令行工具
GWT工具包中提供了几个非常适用的小工具来帮助我们更快的建立GWT应用开发环境:projectCreator、applicationCreator、junitCreator。
* projectCreator
创建在Eclipse中开发GWT应用所需要的项目基本文件和可选的Ant buildfile文件。
* applicationCreator
applicationCreator命令用于创建基本的HelloWorld!应用和GWT应用开发环境。
* junitCreator
生成junti测试代码。
1.动态,可重用的UI组件
GWT提供的组件库使用户可以很容易的开发出漂亮的UI, 每个组件对应于GWT的一个类。在本文的第二部分会比较详细的介绍GWT对UI的支持。
2.简单的RPC调用
使用GWT,可以方便的实现客户端和服务器端的通信,特别是使得异步通信变的非常简单。在本文的后面部分将对利用GWT进行RPC调用进行详细介绍。
3.更加方便的调试
由于在开发阶段不需要生成HTML截面,用户开发的代码实际上是在JVM上运行的,这样用户就可以用传统的调试Java代码的方法对程序进行调试,从而加快了调试的速度,减少了软件开发的时间。
4.浏览器兼容性
在大多数情况下,用GWT开发出来的程序会支持IE、Firefox、Mozilla、Safari和Opera,用户在开发的时候不必担心浏览器的兼容性问题。而浏览器的兼容性问题也是用直接用Javascript进行Ajax应用开发所面临的一个另程序员棘手问题。
5.可扩展性
如果你觉得GWT提供的API不能满足需求,你可以利用JSNI将Javascript语句直接嵌入至Java代码中。

Tags in this post...

面试题 相关文章推荐
Eclipse面试题
Mar 22 面试题
我有一个char * 型指针正巧指向一些int 型变量, 我想跳过它们。 为什么如下的代码((int *)p)++; 不行?
May 09 面试题
JAVA和C++的区别
Oct 06 面试题
DataList 能否分页,请问如何实现?
May 03 面试题
Linux操作面试题
Feb 11 面试题
Linux Interview Questions For software testers
Jun 02 面试题
软件测试面试题
Jan 05 面试题
设计模式的基本要素是什么
Apr 21 面试题
MySQL面试题目集锦
Apr 14 面试题
初级Java程序员面试题
Mar 03 面试题
如何在Shell脚本中使用函数
Sep 06 面试题
介绍一下javax.servlet.Servlet接口及其主要方法
Nov 30 面试题
JavaScript获取当前url根目录(路径)
Feb 19 #面试题
ajax是什么及其工作原理
Feb 08 #面试题
Ajxa常见问题都有哪些
Mar 26 #面试题
如何利用XMLHTTP检测URL及探测服务器信息
Nov 10 #面试题
百度JavaScript笔试题
Jan 15 #面试题
AJax面试题
Nov 25 #面试题
Ajax和javascript的区别
Jul 20 #面试题
You might like
一步一步学习PHP(6) 面向对象
2010/02/16 PHP
php实现的click captcha点击验证码类实例
2014/09/23 PHP
ThinkPHP表单数据智能写入create方法实例分析
2015/09/27 PHP
2款PHP无限级分类实例代码
2015/11/11 PHP
php 无限级分类 获取顶级分类ID
2016/03/13 PHP
Apache PHP MySql安装配置图文教程
2016/08/27 PHP
Jquery AJAX 框架的使用方法
2009/11/03 Javascript
来自国外的页面JavaScript文件优化
2010/12/08 Javascript
jquery下div 的resize事件示例代码
2014/03/09 Javascript
JS折半插入排序算法实例
2015/12/02 Javascript
Node.js编写爬虫的基本思路及抓取百度图片的实例分享
2016/03/12 Javascript
浅析JavaScript Array和string的转换(推荐)
2016/05/20 Javascript
jQuery实现的自适应焦点图效果完整实例
2016/08/24 Javascript
web前端开发upload上传头像js示例代码
2016/10/22 Javascript
js replace()去除代码中空格的实例
2017/02/14 Javascript
基于构造函数的五种继承方法小结
2017/07/27 Javascript
微信小程序上传图片实例
2018/05/28 Javascript
jQuery实现的记住帐号密码功能完整示例
2019/08/03 jQuery
微信小程序实现上传图片裁剪图片过程解析
2019/08/22 Javascript
vue  elementUI 表单嵌套验证的实例代码
2019/11/06 Javascript
node.js +mongdb实现登录功能
2020/06/18 Javascript
[54:56]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第三局
2016/03/06 DOTA
详解Python中的Cookie模块使用
2015/07/06 Python
全面了解python字符串和字典
2016/07/07 Python
python 借助numpy保存数据为csv格式的实现方法
2018/07/04 Python
对pandas通过索引提取dataframe的行方法详解
2019/02/01 Python
用Python徒手撸一个股票回测框架搭建【推荐】
2019/08/05 Python
简单的Python调度器Schedule详解
2019/08/30 Python
python错误调试及单元文档测试过程解析
2019/12/19 Python
Python闭包及装饰器运行原理解析
2020/06/17 Python
HTML5 input新增type属性color颜色拾取器的实例代码
2018/08/27 HTML / CSS
医学检验专业个人求职信范文
2013/12/04 职场文书
护士辞职信模板
2014/01/20 职场文书
无偿献血倡议书
2014/04/14 职场文书
写给医护人员的一封感谢信
2019/09/16 职场文书
python语言中pandas字符串分割str.split()函数
2022/08/05 Python