华为手机怎么截屏P8与HTC M9 谁是手机中的战斗机

Ajax系列:使用Google Web Toolkit(GWT)开发Ajax
用圣才电子书APP或微信扫一扫,在手机上阅读本文,也可分享给你的朋友。
来源:网络&&& 作者:未知
Ajax技术是当前开发web应用的非常热门的技术,也是Web 2.0的一个重要的组成部分。然而如果用传统的方式Javascript进行Ajax开发的话,就会使得应用程序非常难以进行调试,从而降低了生产效率。Google最近推出的GWT有望为我们解决这个难题,GWT是一个开发Ajax应用的框架,它使程序员用Java同时开发客户端和服务器端的代码。GWT的编译器会把用于开发客户端的Java代码转化成Javascript和Html,而程序员不用关心这一转换过程。这样程序员就可以在自己喜欢的Java IDE里面开发自己的Ajax应用程序。
本文主要从以下几个方面进行介绍:
1、 GWT特性简介
2、 用GWT进行UI开发
3、 用Javascript开发Ajax应用简介
4、 用GWT进行Ajax开发
GWT特性简介
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代码中。
用GWT进行UI开发
在本文的这一部分,我们将探讨一下GWT对UI开发的支持。在GWT中,包含我们进行Web开发所需要的大部分组件,比如按纽(Button),文本框(Text box)等。图一显示了部分GWT所支持的UI组件。从图片的显示效果来看,利用GWT可以做出非常漂亮的UI。
图一:GWT支持的部分UI组件
值得一提的是,在每个UI组件是必须放在一个称之为面板(Panel)的控件里面。而面板具有不同的风格,这也决定了UI的风格。图二显示了GWT所支持的部分面板。
图二:GWT支持的部分面板
在看过这些组件之后,我们接下来用一个实验来讲述怎样把UI组件添加到页面上。这个实验的最终结果是一个登录框界面。
在开始我们的实验之前,我们需要准备一下GWT环境,首先要到Google的网站上去下载一个Windows版本的GWT,目前的版本号是1.0.21。然后要在机器上配置好JDK环境,具体的配置方法网络上有大量文档,这里就不再详细介绍。由于我们这个实验是在Eclipse开发环境下进行的,所以你还需要一个Eclipse的环境,可以到Eclipse的官方网站下载Eclipse的开发环境。接下来我们详细介绍试验过程。
1. 创建Eclipse工程
我们可以利用GWT自带的一个批处理文件projectCreator.cmd来创建Eclipse的工程。如图三所示,我们创建了一个名字为myProject的工程,存放在当前目录的myProject子目录下面,关于批处理文件projectCreator.cmd的详细用法,请参见Google关于GWT的帮助文档。
图三:用GWT创建Eclipse工程
2. 创建GWT应用程序
在创建完Eclipse工程myProject之后,我们利用GWT自带的另外一个批处理文件applicationCreator.cmd来创建一个GWT应用程序。图四显示了创建一个GWT应用的过程。大家注意到这个批处理文件接受一个名为 -eclipse 的参数,这个参数正是指定了一个Eclipse的工程,我们的例子中指定为我们刚创建好的Eclipse工程myProject。
图四:创建GWT应用程序
3. 导入Eclipse工程
在创建完Eclipse工程和GWT应用程序框架后,我们接着将Eclipse工程导入到Eclipse开发环境当中以进行进一步的开发,具体的导入过程不再详细介绍。导入后的工程结构如图五所示。
图五:导入Eclipse工程
6.添加UI组件
在导入工程后,我们会发现工程里面有一个名字为DemoClient的Java文件。这个文件是在运行applicationCreator.cmd批处理文件时创建的,我们现在需要做的工作就是在这个Java文件上加入自己需要的UI组件。我们在这个文件中加入了五个组件,分别是:两个Label,一个Button,一个TextBox和一个PasswordTextBox。代码列表Listing 1中列出了本程序的所有代码。
Listing 1:Sample GWT Application
1  package com.sample.myProject.
2  import com.google.gwt.core.client.EntryP
3  import com.google.gwt.user.client.ui.B
4  import com.google.gwt.user.client.ui.HorizontalP
5  import com.google.gwt.user.client.ui.L
6  import com.google.gwt.user.client.ui.PasswordTextB
7  import com.google.gwt.user.client.ui.RootP
8  import com.google.gwt.user.client.ui.TextB
* This class is used to demostrate how to add widget onto the Web page
9  public class DemoClient implements EntryPoint {
  * This is the entry point method, when the module is load, this method
  * will be automatically invoked.
10   public void onModuleLoad() {
11      Label labelName = new Label();
12      Label labelPassword = new Label();
13      TextBox tbName = new TextBox();
14  PasswordTextBox tbPassword = new PasswordTextBox();
15  Button button = new Button();
17      labelName.setText(&Name:    &);
18      labelPassword.setText(&Password: &);
19      button.setText(&submit&);
20      
21      HorizontalPanel hPanel = new HorizontalPanel();
22      HorizontalPanel hPanel2 = new HorizontalPanel();
23      
24      hPanel.add(labelName);
25      hPanel.add(tbName);
26      hPanel2.add(labelPassword);
27      hPanel2.add(tbPassword);
28      RootPanel.get().add(hPanel);
29      RootPanel.get().add(hPanel2);
30      RootPanel.get().add(button);
31     }
接下来我们分析一下这些程序代码,注意到类DemoClient继承自EntryPoint,所有需要最终被翻译成HTML页面的类都必须继承自EntryPoint,并且需要重写onModuleLoad方法,这个方法会在模块被装载的时候自动调用。因此我们也就需要把我们的添加组件的代码放到这个函数里面。
程序的11至15行分别创建了5个组件的实例。分别是两个Label,一个Button,一个TextBox和一个PasswordTextBox。然后程序的17到19行分别设置了两个Label组件以及一个Button组件的显示内容。程序的21行和22行穿件两个Panel对象,这两个Panel对象的类型都是水平Panel对象。也就是说放在这种Panel里面的组件是被水平排列的。程序的24行到27行分别向这两个Panel对象中加入TextBox组件和Label组件。在程序的最后,将刚才创建好的两个Panel对象以及一个Button对象加到最外层的Panel当中。
7.编译应用程序
在代码开发完成后,我们可以双击工程里面的DemoClient-compile.cmd批处理文件来将我们开发出来Java文件编译成Javascript和HTML。编译后的文件将存放在工程的根目录下面的www子目录中。
8.运行程序
编译好程序后,我们会发现生成了一个名字为DemoClient.html的HTML文件,双击这个文件,程序的运行结果如图六所示:
图六:程序运行结果
在这一部分,我们主要讨论了如何将UI组件添加到Web页面中,而这些组件如何与远程服务器进行异步的交互将在下面的章节中进行讨论。
用Javascript开发Ajax应用
为了使用户能更清楚地理解用GWT开发Ajax应用与用传统的Javascript开发Ajax应用的不同,文章的这一部分将简要介绍如何利用Javascript对象进行Ajax应用的开发。
大家都知道Ajax技术中的一个核心对象是XMLHttpRequest对象,这个对象支持异步请求,所谓异步请求既是当客户端发送一个请求到服务器的时候,客户端不必一直等待服务器的响应。这样就不会造成整个页面的刷新,给用户带来更好的体验。而当服务器端响应返回时,客户端利用一个Javascript函数对返回值进行处理,以更新页面上的部分元素的值。
由于在IE和其他浏览器上声称XMLHttpRequest对象的方法不一样,所以我们用Javascript创建XMLHttpRequest对象的时候必须区分不同的浏览器。创建一个XMLHttpRequest对象的方法如清单2 中的代码所示。
清单2:创建XMLHttpRequest对象
1  function createObject(){
2   try {
3     xmlHttpRequest = new ActiveXObject(&Msxml2.XMLHTTP&);
4   } catch (e1) {
5     try {
6      xmlHttpRequest = new ActiveXObject(&Microsoft.XMLHTTP&);
7     } catch (e2) {
8      xmlHttpRequest =
9     }
11 if (!xmlHttpRequest) {
12     xmlHttpRequest = new XMLHttpRequest();
14   return xmlHttpR
在创建好XMLHttpRequest对象之后,来看一下如何与server端进行异步的交互。清单3中列出了与服务器段进行交互的代码
清单3:与服务器端进行交互
1  function ajaxSample() {
2    var xmlHttpRequest = createObject();
3    var url = &/sampleServlet?userName=Jason&;
4    xmlHttpRequest.open(&GET&, url, true);
5    xmlHttpRequest.onreadystatechange = updateP
6    xmlHttpRequest.send(null);
这段代码演示了如何与服务器端进行交互的过程。程序的第2行首先获得一个XMLHttpRequest对象,程序的第三行指定了服务器端响应客户端的请求的地址。程序的第4行利用XMLHttpRequest对象打开一个连接,第一个参数指定用GET方法传递参数,第二个参数指定了接受请求的URL,在我们的例子中是一个Servlet,最后一个参数设置成true意味着将要发出的请求是一个异步的请求。程序的第5行指定了回调函数,也就是当服务器端返回结果后执行哪个Javascript函数。
这一部分对如何利用Javascript进行Ajax开发作了一个简要的介绍,下面我们将详细介绍如何利用GWT进行Ajax应用的开发。
用GWT进行Ajax开发
在文章的第二部分我们已经掌握了如何利用GWT创建一个工程并在工程里添加一个GWT应用程序,同样我们这一部分也需要创建一个GWT的工程,并添加一个GWT应用程序,由于默认创建的GWT程序不含有Server端的示例代码,我们必须手工加进去。我们创建好的工程GWTSample如图七所示。我们将要介绍的实例主要功能是采用异步通信的方式从服务器端取出一个字符串显示在HTML页面上。这个例子虽然简单,但却包含了如何利用GWT进行Ajax开发的主要流程。
图七:GWTSample工程结构
大家注意到我们这个工程里面有个com.sample.myProject.server包,这个包里面包含有运行在服务器端的代码。我们从客户端发送的请求也是发送到这个包里面的一个Servlet上去的。
为了进行异步调用,在Client端必须定义一个继承自接口RemoteService的接口,在我们的这个例子中,我们定义了接口SampleService,SampleService的代码如清单4所示。
1  package com.sample.myProject.
2  import com.google.gwt.user.client.rpc.RemoteS
3  public interface SampleService extends RemoteService{
4  //The implementation of this method is used to return a string
5  String getString();
大家注意到这个接口继承自RemoteService,并且声明了一个方法getString();,这个方法会在服务器端的代码中实现。当然,大家可能现在已经意识到,这里声明的方法就是我们采用异步调用方式所能够调用的方法。
在声明完这个接口之后,我们还必须声明另外一个异步调用接口,在我们的例子中是接口SampleServiceAsync,这个接口里声明的方法名称必须与SampleService里面的相同,但是多个一个类型为AsyncCallback的参数,接口SampleServiceAsync的代码清单如清单5所示:
清单5:SampleServiceAsync代码清单
1  package com.sample.myProject.
2  import com.google.gwt.user.client.rpc.AsyncC
3  public interface SampleServiceAsync {
4  void getString(AsyncCallback callback);
在客户端定义完接口之后,我们必须在服务器端实现这个接口,在我们的例子中,类SampleServiceImpl实现了接口SampleService,同时你也会注意到SampleServiceImpl也继承了类RemoteServiceServlet,而RemoteServiceServlet是HttpServlet的一个子类,这样我们的客户端的请求就可以提交到Servlet SampleServiceImpl上面。类SampleServiceImpl的代码清单如清单6所示:
清单6:SampleServiceImpl代码清单
1  package com.sample.myProject.
2  import com.google.gwt.user.server.rpc.RemoteServiceS
3  import com.sample.myProject.client.SampleS
4  public class SampleServiceImpl extends RemoteServiceServlet implements
5   SampleService {
6     public String getString() {
7     return &This string is from server&;
8     }
最后我们来看一下类DemoClient,这个类和我们在第二部分创建的工程myProject中的类DemoClient是同一个类型的。只不过在我们这个工程中我们使用它来进行向server端的异步调用。清单7列出了类DemoClient的代码。
清单7:DemoClient代码清单
1  package com.sample.myProject.
2  import com.google.gwt.core.client.EntryP
3  import com.google.gwt.core.client.GWT;
4  import com.google.gwt.user.client.rpc.AsyncC
5  import com.google.gwt.user.client.rpc.ServiceDefT
6  import com.google.gwt.user.client.ui.B
7  import com.google.gwt.user.client.ui.ClickL
8  import com.google.gwt.user.client.ui.L
9  import com.google.gwt.user.client.ui.RootP
10  import com.google.gwt.user.client.ui.W
* This class is used to demostrate hwo to
* interact with the server client in asynchronized
11  public class DemoClient implements EntryPoint {
12    public void onModuleLoad() {
13  final SampleServiceAsync sampleService = (SampleServiceAsync)
14   GWT.create(SampleService.class);
15    ServiceDefTarget target = (ServiceDefTarget)sampleS
16    String staticResponseURL = GWT.getModuleBaseURL();
17    staticResponseURL += &/getStringService&;
18    target.setServiceEntryPoint(staticResponseURL);
20    final Label label = new Label();
21    final Button button = new Button(&Get String&);
22    button.addClickListener(new ClickListener() {
23      public void onClick(Widget sender) {
24        sampleService.getString(new AsyncCallback() {
25          public void onSuccess(Object result) {
26            label.setText((String) result);
27          }
28          public void onFailure(Throwable caught) {
29            label.setText(caught.getMessage());
30          }
31        });
32      }
33    });
34    RootPanel.get(&1&).add(button);
35    RootPanel.get(&2&).add(label);
代码的第13行得到了一个实现了接口SampleServiceAsync的类的实例。第15行创建了一个ServiceDefTarget对象的一个实例,通过这个对象可以设置请求的目的地。程序的第18行设置了请求的目的地的URL,在我们的例子中是&/getStringService&,这个URL会在web.xml文件中被mapping到servlet SampleServiceImpl上。程序的22行到33行为我们添加的button设置了单击响应事件。在单击响应事件中调用sampleService的getString(AsyncCallback callback);方法。这个方法是用来进行异步的远程过程调用的(RPC).并且在实现接口AsyncCallback的代码中指定了回调函数,当远程过程调用成功后就执行onSuccess(Object result)函数,其中result中存放有从服务器端返回的结果.。在远程工程调用失败后就执行onFailure(Throwable caught)函数。程序的最后把Button组件和Label组件加到panel中。
现在我们已经完成了程序的开发,图八显示了我们程序的运行结果,在点击Button后,右边回打出一句话来,重要的是这句话是以异步的方式从服务器端取得的,不需要进行页面的刷新,怎么样,现在是不是也想用GWT进行Ajax应用开发了呢?
图八:RPC调用示例
本文主要对用 GWT 进行 Ajax 开发进行了比较详细的介绍,并通过与传统的Ajax开发方式进行比较,使读者能更清楚地理解它们之间的区别,最后我们可以看出用GWT进行Ajax开发可以使得程序员免受调试Javascript之苦,并且GWT自动处理了浏览器之间的兼容性问题,这些都会使得开发更加容易,快捷。因此,用GWT进行Ajax开发是一种比较好的方式。希望本文能为读者学习GWT进行Ajax的开发有所帮助。
小编工资已与此赏挂钩!一赏一分钱!求打赏↓ ↓ ↓
如果你喜欢本文章,请赐赏:
已赐赏的人
我的电子书> IE8.0.上 GWT2.0 的项目 请求不被执行
IE8.0.上 GWT2.0 的项目 请求不被执行
woshizh & &
发布时间: & &
浏览:2 & &
回复:0 & &
悬赏:0.0希赛币
IE8.0.下 GWT2.0 的项目 请求不被执行
有一个自动刷新的功能:没3秒钟执行一次查询操作,发现 在 IE8.0. 下, 此功能不能够正常执行。在火弧与IE7 下都没有问题。经查看原来是 IE8.0.& 下的缓存导致的,解决办法:在请求的URL 上,带一个随机的参数,以防止请求“被缓存”。
本问题标题:
本问题地址:
温馨提示:本问题已经关闭,不能解答。
暂无合适的专家
&&&&&&&&&&&&&&&
希赛网 版权所有 & &&966,690 三月 独立访问用户
语言 & 开发
架构 & 设计
文化 & 方法
您目前处于:
采访与书摘《Pro Web 2.0 Application Development with GWT》
采访与书摘《Pro Web 2.0 Application Development with GWT》
日. 估计阅读时间:
道AI风控、Serverless架构、EB级存储引擎,尽在!
相关厂商内容
2.GWT是用Java开发Web2.0应用的一种方式。在众多选择中,您为什么对它偏爱有加呢?
我第一个创业项目(MyHippocampus)是尝试开发一种通用存储工具,有点像《梦断代码》中的Chandler,但我的项目中涉及更多的虚拟概念。首先,高度虚拟的是一个Flash程序,这部分我总觉得不太满意,我很讨厌实现Flash程序和Java服务器连接的那部分。之前我做过很多 Swing方面的开发,所以对我来说GWT就非常自然,我尤其喜欢的是能够在客户和服务器端复用同一个对象。我不知道GWT是不是也会支持那些我放弃了但却正蒸蒸日上的类似flash类型的UI。
3. GWT1.5是最近发布的,而您的书也正是基于这个1.5版本之上。在您看来,这个新版本中加入的最有价值的特性是什么?
我觉得对于这个问题,答案是随着时间而变化的。最初,GWT1.5只是为了迁移到Java1.5的使用上来。但现在我们所得到的则是一个令人惊喜的发布。编译器优化程度令人震惊。GWT缔造了一个神话,让您的程序不需要修改任何代码都能在GWT编译器优化的帮助下运行得越来越快。您可以参考Ray Cromwell的一个关于GWT Extreme的出色的演讲&&/2008/06/google-io-gwt- extreme-presentation.html,从中可以了解到它所带来的影响。 ImageBundles不是一个全新的概念,但一旦您尝试使用这个特性,会完全为它所折服。30个图像永远缓存在单一HTTP中而不给您添加任何负担?的确。1.5中,由于注释支持的关系,这些缓存对象会被清理掉,但在孵化器中有一些优秀的代码能够帮助您把ImageBundles的概念延伸到其它类型的资源缓存上。
4. 您书中有一章特别解释了怎样针对搜索引擎来优化GWT站点。将Ajax应用变得可以被搜索这个需求很多时候都会被忽略或者无法正确实现。对于使用GWT创建Web应用的开发者来说,您觉得充分利用各种工具箱以及Web2.0功能的过程中,什么是最需要注意的?
显然,SEO是一些应用必须具备的特性,而这项特性在富应用中又很难实现。我觉得,ToCollege.net解决方案刚好是一种把RIA应用向搜索引擎敞开怀抱的轻量、不易入侵的方式。书中另外提到的一个主要概念是我常用的command pattern的使用。这是一个循环主题,我因此能够使用同一个结构来避免XSRF攻击;实现与Hibernate的集成;向客户端添加缓存,还能够很自然地让您的站点通过Google Gears在离线状态下同样正常工作。最后,本书还花了很多时间来讲安全,这也是我们非常注重的一个话题。
5. 有人曾对GWT及其自动生成代码的功能进行抨击,说如果通过一种语言(Java)来编写另一种语言(JavaScript)的程序的话,会失去目标语言(JavaScript)的所有优点。您对这种说法是怎么看的?
这个问题问得很好。老实说,在我刚开始研究怎样创建富Web2.0应用的时候,我对JavaScript不是非常了解。一想到要编写大量针对浏览器的代码,要面对IE6的bug,我就毛毛骨悚然。最近一段时间以来,我在PatientsLikeMe工作中用JavaScript编写了大量代码,不得不说的是JavaScript世界比我最初想象的要好很多。时间加上开放的头脑,您完全可以写出干净利落的JavaScript代码,只需要花点时间好好研究一下最佳用法。JavaScript这门语言很有意思,但如果您只是试图通过写JavaScript来生成Java,那您肯定会对它深恶痛绝。对于优秀的开发人员来说,JavaScript可以起到非常好的作用,但仍然局限在一定程度以内。
GWT诞生的原因是,Google发现JavaScript不适合大型项目。他们有大量最优秀的开发人员,遵循最佳用法的原则进行开发,但项目很大的时候,他们发现外部工具的支持开始比干净的JavaScript代码更胜一筹。我觉得在考虑使用GWT的时候,牢记这点是非常有用的。GWT不是为初级开发人员创建的EZ-AJAX,也不是为那些不想学JavaScript的人而设计的,而是Google的天才开发人员在为开发更大型的富网络应用而抓狂的时候所激发的点子。
6.很多使用GWT的开发人员都极为赞赏的一点是他们因此不需要再亲自验证应用在各种浏览器下的运行情况。您觉得这是GWT强有力的优势吗?
不见得。正如我之前提到的,在我开始运用GWT的时候,这是个非常引人注目的卖点,但是说实话,我觉得有点过高估计了这个问题。从这个角度来说,GWT的确很好用,但一些JavaScript解决方案也不见得很烂。您可以找到很多相关的例子或者开发框架。当然,有时候您需要考虑把元素放在popup后面,这样form元素就不会混淆其中,当然您应该考虑一些关于漏洞的问题,但通常来说,跨浏览器开发中真正的难题是CSS,而不是JavaScript。 Prototype/JQuery/etc是不错的类库。所以从这点来看,GWT非常不错,但我不希望大家用GWT来跑一些非常基础、只需要几行 Script.aculo.us的东西。如果您只是构架一个简单的网站,那使用GWT就可能有点小题大作了。
7.在GWT生成JavaScript文件之后,您还常常需要在各种浏览器下debug您的应用程序吗?如果要那样debug的话,您觉得容易找到并修正bug吗?
从1.3起,我就没必要在浏览器下debug那些生成的JavaScript了,即使有时候有bug,95%都是我的错。GWT生成的代码都很对。实际上,还不止这些。GWT还能省去大量内存问题,甚至还能修补JavaScript开发人员的疏忽。GWT能够在您毫无之觉的情况下修补一些漏洞。
CSS完全是另外一码事。关于CSS,我最后要做的都只是编译而已。我的基本工作流是,先在hosted模式下实现功能项,然后就只是等待几秒钟的代码刷新时间。然后编译,再在Firefox下查看,选用Firefox是因为因此可以借用Firebug的力量来查看CSS是否正确。再然后,把CSS 迁回到项目中来,查看要让该CSS在IE下正常显示还需要做些什么。但是,很长一段时间以来,我都没有必要再把生成的JavaScript以pretty 模式输出。
8. 很多人认为,像GWT这样自动生成代码或者精细的JavaScript开发框架的出现意味着传统的&Web平台&已经发展到了它的极点,应该由一些更先进的事物来替代了。您对这个观点怎么看?
这正是问题所在!我认同这个观点。这个观点很有意思,但也带着些讥讽。我觉得自己对REST不断增长中的热情实际上也使得我越来越感到web平台实际上在拖大家的后腿。REST用起来也很好,但我常常觉得它应该在那些服务器只负责REST服务,而客户端负责与UI相关的一切事务的世界里会运行得更好。客户端越&富有&,两端就越难覆写所需功能项,把应用逻辑布置在服务器端就愈发显的奇怪。InfoQ关于SOFEA和 ThinServerArchitecture的文章在这点上着实影响了我的看法。我觉得GWT在下面这个情景中运用会非常恰当。比方说,您有一个可以在客户和服务器两端运行的代码库,然后您可以把MVC栈从服务器端转移到客户端,这对于应用的可伸缩性以及用户体验都非常有帮助。但问题的本质是,我们是否需要引进新事物。我觉得还没有这个必要。我们有可能正在接近将应用逻辑布置在服务器端的末期,不仅仅将浏览器作为用户代理。浏览器的应用无处不在,而 GWT帮助您解决很多相关问题,除此之外,您还能从Google Gears中受益。最后,如果您还想要实现更多,那么Java WebStart是不错的选择。
9. 作为GWT工具箱的用户,您期望它将来的发布中引入一些怎样的新特性?
你想知道我的&白日梦&吗?我很希望GWT能够在动态语言中使用。当然我也知道,这也可能意味着失去极好的refactoring支持以及GWT为比较大的团队提供的其它一些优点。但开发GUI的人们强烈期盼对动态语言的支持。如果能够在GWT项目的一些较为动态的元素上混合使用Groovy,那多有意思阿!
阅读英文原文:。
志愿参与InfoQ中文站内容建设,请邮件至。也欢迎大家到参与我们的线上讨论。
Author Contacted
告诉我们您的想法
允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p
当有人回复此评论时请E-mail通知我
允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p
当有人回复此评论时请E-mail通知我
允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p
当有人回复此评论时请E-mail通知我
赞助商链接
InfoQ每周精要
订阅InfoQ每周精要,加入拥有25万多名资深开发者的庞大技术社区。
架构 & 设计
文化 & 方法
<及所有内容,版权所有 &#169;
C4Media Inc.
服务器由 提供, 我们最信赖的ISP伙伴。
北京创新网媒广告有限公司
京ICP备号-7
注意:如果要修改您的邮箱,我们将会发送确认邮件到您原来的邮箱。
使用现有的公司名称
修改公司名称为:
公司性质:
使用现有的公司性质
修改公司性质为:
使用现有的公司规模
修改公司规模为:
使用现在的国家
使用现在的省份
Subscribe to our newsletter?
Subscribe to our industry email notices?
我们发现您在使用ad blocker。
我们理解您使用ad blocker的初衷,但为了保证InfoQ能够继续以免费方式为您服务,我们需要您的支持。InfoQ绝不会在未经您许可的情况下将您的数据提供给第三方。我们仅将其用于向读者发送相关广告内容。请您将InfoQ添加至白名单,感谢您的理解与支持。}

我要回帖

更多关于 华为手机官网商城 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信