`

java教程 gwt项目开发的经验

    博客分类:
  • GWT
阅读更多

在做一个gwt项目的开发,我会把在项目开发中遇到的问题以及解决方法记录下来(有很多是同事,也整理放在其中了),以供同道中人参考,少走不该走的路,也希望与同仁交流。

12,gwt中使用float样式实现
      css的float样式在ie与firefox中对应的dom属性名不同,所以不能直接用如下的语句
               DOM.setStyleAttribute(elem,"float", "left");
      可以这样使用(在ie与firefox都可以)

public   static   native   void  setStyleAttributeEx(Element elem, String jsStyle, String value)
    
/**/ /* -{
         if(jsStyle=="float" || jsStyle == "styleFloat" || jsStyle =="cssFloat")
         {
         jsStyle = (elem.style.styleFloat || elem.style.styleFloat=="")  ? "styleFloat":"cssFloat";
         }
         elem.style[jsStyle]=value;
     }-
*/
;


> 11,文件下载(downloat) 计划中

> 10,阻止事件传到父对象

> 9,文件上传客户端(隐藏表单)


8,不换行:表格字符、多种widget的组合

// div中的文本不换行
        Label label  =   new  Label( " div中的文本不换行 " );
        
// css       white-space: nowrap;
        
// gwt实现:
        DOM.setStyleAttribute(label.getElement(),  " white-space " " nowrap " );

        
// table中的文本不换行
        
// 先把文件放入一个div中,再放到表格中,或者设置table的td的css样式

        
// 不同类型的widget在div中不换行
        
// css float:left;clear:none
        
// float:left 元素浮于左边;clear:none 元素两边都可以有浮动对象(如果不允许就会直接换行)
        
// gwt实现
        FlowPanel div  =   new  FlowPanel(); // 实际上flowpanel就是一个div
        Label one  =   new  Label( " one " );
        DOM.setStyleAttribute(one.getElement(), 
" clear " " none " );
        
// 注:原gwt不支持float,所以这里用扩展的
        DomEx.setStyleAttributeEx(one.getElement(),  " float " " left " );
        Image image 
=   new  Image();
        DOM.setStyleAttribute(image.getElement(), 
" clear " " none " );
        DomEx.setStyleAttributeEx(image.getElement(), 
" float " " left " );

        div.add(one);
        div.add(image);

 

7,css的(边框)margin、border、padding、width、height与dom对象的属性clientWidth、offsetWidth、offsetHeight等的关系及gwt的获取与设置

public   static   native   int  getClientHeight()  /**/ /* -{
    if ($wnd.innerHeight)
      return $wnd.innerHeight;
    return $doc.body.clientHeight;
  }-
*/
;
改为:
public   static   native   int  getClientHeight()  /**/ /* -{
    if ($wnd.innerHeight)
      return $wnd.innerHeight;
    if($doc.compatMode=='CSS1Compat') return $doc.documentElement.clientHeight;//关键
    return $doc.body.clientHeight;
  }-
*/
;

         宽度与此相似
       二,块(容器)的“边框”与高度(参考:http://bbs.blueidea.com/thread-2692909-1-1.html为什么IE6下容器的宽度和FF解释不同
         不同的浏览器,就是相同的浏览器在不同的模式下的解释是不一样,没有找到一个比较好的计算他值的关系,所以在写xhtml/html时一定要注意,自己网页的规范与标准,如果你的页头有这样的信息

<? xml version="1.0" encoding="utf-8" ?>
<! DOCTYPE html 
PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
>
< html  xmlns ="http://www.w3.org/1999/xhtml"  lang ="zh-CN" >  
< head >
< meta  http-equiv ="Content-Type"  content ="application/xhtml+xml; charset=utf-8"   />
< title > 无标题文档 </ title >
</ head >
< body >
< div  style ="height:100px; width:150px; border:10px solid red;margin:7px; padding:13px;" > 标准模式 </ div >
</ body >
</ html >

,在ie7与firefox2下有如下的结果:
         offsetHeight:padding-top+padding-bottom+boder-top-width+border-bottom+height
         clientHeight:offsetHeight - (border-top-width +border-bottom-width)

    对于行元素的处理只能一个一个的试了,我没有找到通用的公式。!!!


6,学习开发资源
      要做好gwt程序,客户端方面,有这些知识比较好:java、javascript、css、html(排列有先后),至于服务方面的我也说不清楚
      官方主站:http://code.google.com/webtoolkit/
      官方开源站:http://code.google.com/hosting/  打开网页在里面输入gwt,会有很多相关的开源与代码
     开发工具或库
         gwt 官方网站上第三方工具: http://code.google.com/webtoolkit/thirdparty.html
               gwt designer :可视化的eclipse插件开发工具,易上手,入门比较好
               gwt widget library :开源的gwt扩展库,
               wireflexsoft vistafei :是个可视化的eclipse插件开发工具,易上手,没有gwt designer做的好用
         googlipse :eclipse插件,无可视化,功能少一些,不过免费的
         firebug :firefox的插件,能非常方便的查看DOM、调试javascript、支持不同浏览器的控制台,支持动态修改。在firefox下只要这一个插件,开发就顺手了,ie下要多介绍几个,不过都不如firebug
         DevToolBar :ie的插件,微软官方提供
         WebDevHelper :ie的插件要.net framework2.0 ,软件工程师提供
         Ie WebDeveloper : 功能也比较多,好像要收费

         开源库或参考(排名不分先后)

         gwtwindowmanager:http://code.google.com/p/gwtwindowmanager/
         gwtwidgetlist:http://gwtpowered.dabbledb.com/publish/gwtwidgetlist/2ddeb373-1746-4642-836d-931fa7a2778b/gwtwidgetlist.html
         http://www.brandonandkim.com/gwtblog/
         基于gwt的一个开源项目:http://sourceforge.net/projects/pdune
         gwt的组件库:http://gwt.components.googlepages.com/
         http://jaxzin.com/2006/09/release-of-my-google-web-toolkit.html
         http://code.google.com/p/rocket-gwt/
         http://www.vspu.ru/is/sites/gwt-jds/index.htm
         http://www.gwtwindowmanager.org/
         http://simile.mit.edu/timeline/
。。。。。


5,给gwt的ui组件增加事件

   一,用gwt的事件机制实现,以按钮为例,增加鼠标事件

package  com.mycompany.project.client;
import  com.google.gwt.user.client.DOM;
import  com.google.gwt.user.client.Event;
import  com.google.gwt.user.client.ui.Button;
import  com.google.gwt.user.client.ui.MouseListener;
import  com.google.gwt.user.client.ui.MouseListenerCollection;

public   class  ButtonEx  extends  Button {
    
private  MouseListenerCollection mouseListeners;
    
public  ButtonEx() {
        
super ();
        sinkEvents(Event.MOUSEEVENTS);    
// 事件类型,具体参考gwt的Event类
    }
    
public   void  addMouseListener(MouseListener listener)
    {
        
if (mouseListeners  ==   null )
            mouseListeners 
=   new  MouseListenerCollection();
        mouseListeners.add(listener);
    }
    
public   void  removeMouseListener(MouseListener listener)
    {
        
if (mouseListeners  !=   null )
            mouseListeners.remove(listener);
    }
    
public   void  onBrowserEvent(Event event)
    {
        
super .onBrowserEvent(event);     // 调用父类的,如果想取消父类的事件也可以不用调用
        
switch  (DOM.eventGetType(event))
        {
        
case  Event.ONMOUSEDOWN:
        
case  Event.ONMOUSEUP:     
        
case  Event.ONMOUSEMOVE:
        
case  Event.ONMOUSEOVER:
        
case  Event.ONMOUSEOUT:
            
if (mouseListeners  !=   null )
                mouseListeners.fireMouseEvent(
this , event);
            
break ;
        }
        
// super.onBrowserEvent(event); 这一句也可以放在这里调用,这样的话,就先触发我们增加的事件
    }
}

 

   使用代码

 

package  com.mycompany.project.client;
import  com.google.gwt.core.client.EntryPoint;
import  com.google.gwt.user.client.Window;
import  com.google.gwt.user.client.ui.MouseListener;
import  com.google.gwt.user.client.ui.RootPanel;
import  com.google.gwt.user.client.ui.Widget;
public   class  ExpMouseOver  implements  EntryPoint {
    
public   void  onModuleLoad() {
        ButtonEx button 
=   new  ButtonEx();
        button.addMouseListener(
new  MouseListener(){
            
public   void  onMouseDown(Widget sender,  int  x,  int  y) {
                Window.alert(
" onMouseDown " );
            }
            
public   void  onMouseEnter(Widget sender) {
                Window.alert(
" onMouseEnter " );
            }
            
public   void  onMouseLeave(Widget sender) {
                Window.alert(
" onMouseLeave " );
            }
            
public   void  onMouseMove(Widget sender,  int  x,  int  y) {
                Window.alert(
" onMouseMove " );
            }
            
public   void  onMouseUp(Widget sender,  int  x,  int  y) {
                Window.alert(
" onMouseUp " );
            }
        });
        RootPanel.get().add(button);
    }
}

在“4,按钮的鼠标进出样式”中的实现也可以在事件的响应中修改按钮的css。

    二,用jsni实现,以TextBox的双击事件为例

 

package  com.mycompany.project.client;
import  java.util.Iterator;
import  java.util.Vector;
import  com.google.gwt.user.client.Element;
import  com.google.gwt.user.client.ui.TextBox;
import  com.google.gwt.user.client.ui.Widget;
public   class  TextBoxEx  extends  TextBox {
    
private  DblClickListenerCollection dblClickListener;
    
private   void  onDblClick()
    {
        
this .dblClickListener.fireDbLClick( this );
    }
    
private   native   void  addJsniEvent(Element elem) /* -{
        var old = elem.ondblclick;//注意这里是小写啊
        var jsthis = this;
        elem.ondblclick=function(){
            jsthis.@com.mycompany.project.client.TextBoxEx::onDblClick()();//注意这里是两对括号啊
            if(old)old();
        };
    }-
*/ ;
    
public   void  addDblClickListener(DblClickListener listener)
    {
        
if ( this .dblClickListener  ==   null )
        {
            
this .dblClickListener  =   new  DblClickListenerCollection();
            addJsniEvent(
this .getElement());
        }
        
this .dblClickListener.add(listener);
    }
    
public   void  removeDblClickListener(DblClickListener listener)
    {
        
if ( this .dblClickListener  !=   null )
            
this .dblClickListener.remove(listener);
    }
    
private   static   class  DblClickListenerCollection  extends  Vector
    {
        
public   void  fireDbLClick(Widget sender) {
            
for  (Iterator it  =  iterator(); it.hasNext();) {
                DblClickListener listener 
=  (DblClickListener) it.next();
              listener.onDblClick(sender);
            }
          }
    }
    
public   static   interface  DblClickListener{
        
public   void  onDblClick(Widget sender);
    }
}

使用代码

 

package  com.mycompany.project.client;
import  com.google.gwt.core.client.EntryPoint;
import  com.google.gwt.user.client.Window;
import  com.google.gwt.user.client.ui.RootPanel;
import  com.google.gwt.user.client.ui.Widget;
import  com.mycompany.project.client.TextBoxEx.DblClickListener;
public   class  ExpMouseOver  implements  EntryPoint {
    
private  TextBoxEx text;
    
public   void  onModuleLoad() {
        text 
=   new  TextBoxEx();
        text.addDblClickListener(
new  DblClickListener(){
            
public   void  onDblClick(Widget sender) {
                Window.alert(
" DblClick " );
            }
        });
        RootPanel.get().add(text);
    }
}

 

   
4,按钮的鼠标进出样式
    在css中没提供直接设置按钮的鼠标进出样式,这里用鼠标事件来实现,在gwt中可以写一个Button的子类,并为其增加鼠标事件,也可以直接用脚本来实现(jsni),综合比较了一上,在这里直接用脚本比较好
    一,脚本实现,代码如下

public   class  ExpMouseOver  implements  EntryPoint {
    
private   boolean  first  =   false ;
    
public   void  onModuleLoad() {
        Button button 
=   new  Button();
        DOM.setStyleAttribute(button.getElement(), 
" borderColor " " blue " );
        setMouseOverBorderColor(button.getElement(), 
" red " );
        button.setText(
" 测试 " );
        RootPanel.get().add(button);
    }
    
public   native   void  setMouseOverBorderColor(Element elem,String color) /* -{
        if(this.@com.mycompany.project.client.ExpMouseOver::first) return; //防止多次调用
        var oldColor = elem.style["borderColor"];
        var old = elem.onmouseover;    //取出原事件响应函数(鼠标进入)
        this.@com.mycompany.project.client.ExpMouseOver::first = true;
        elem.onmouseover = function(){
            elem.style["borderColor"] = color;
            if(old) old(); //如果原事件响应函数存在,就运行它
        };
  
        var oldOut = elem.onmouseout; //(鼠标移出)
        elem.onmouseout = function(){
            elem.style["borderColor"] = oldColor;//还原颜色
            if(oldOut) oldOut();
        };
    }-
*/ ;
}

    这里说明一下,这个函数只允许调用一次,有待改进啊!
    如下的是改进版的程序,可以多次调用,这里把颜色的值改成一个成员了

package  com.mycompany.project.client;
import  com.google.gwt.core.client.EntryPoint;
import  com.google.gwt.user.client.DOM;
import  com.google.gwt.user.client.Element;
import  com.google.gwt.user.client.ui.Button;
import  com.google.gwt.user.client.ui.RootPanel;
public   class  ExpMouseOver  implements  EntryPoint {
    
private   boolean  first  =   false ;
    
private  String color;
    
private  Button button;
    
public   void  onModuleLoad() {
        button 
=   new  Button();
        DOM.setStyleAttribute(button.getElement(), 
" borderColor " " blue " );
        setMouseOverBorderColor(button.getElement(), 
" red " );
        setMouseOverBorderColor(button.getElement(), 
" green " );
        button.setText(
" 测试 " );
        RootPanel.get().add(button);
    }
    
public   native   void  setMouseOverBorderColor(Element elem,String color) /* -{
        var jsthis = this;
        jsthis.@com.mycompany.project.client.ExpMouseOver::color = color;
        if(jsthis.@com.mycompany.project.client.ExpMouseOver::first) return; //防止多次调用
        var oldColor = elem.style["borderColor"];
        var old = elem.onmouseover;    //取出原事件响应函数(鼠标进入)
        jsthis.@com.mycompany.project.client.ExpMouseOver::first = true;
        elem.onmouseover = function(){
            elem.style["borderColor"] = jsthis.@com.mycompany.project.client.ExpMouseOver::color;
            if(old) old(); //如果原事件响应函数存在,就运行它
        };
        
        var oldOut = elem.onmouseout; //(鼠标移出)
        elem.onmouseout = function(){
            elem.style["borderColor"] = oldColor;//还原颜色
            if(oldOut) oldOut();
        };
    }-
*/ ;
}


    二 增加Button的鼠标事件实现
       这个的实现放到扩展gwt事件里讨论吧
    希望还有更新的解决方法,在ie与firefox中都能用的。。。
3,元素宽度计算与设置
    相关的函数有:
        DOM.getAbsoluteLeft(Element elem);  //元素elem左上角的“x”坐标(绝对坐标)
        DOM.getAbsoluteTop(Element elem);   //元素elem左上角的“y”坐标(绝对坐标)

        UIObject的方法
            getOffsetHeight()与DOM.getIntAttribute(element, "offsetWidth")等价  //元素的高度
            getOffsetWidth()与DOM.getIntAttribute(element, "offsetWidth")等价  //元素的宽度
              注:高度与宽度函数,是页面显示完成后的高度与宽度
            setHeight(String height)与DOM.setStyleAttribute(element, "height", height)等价
            setWidth(String width)与DOM.setStyleAttribute(element, "width", width)等价
            setPixelSize(int width, int height) //设置高宽度,单位为“px”像素
            setSize(String width, String height) //设置高宽度,是setHeight与setWidth的组合
                注:setPixel(100,120)与setSize("100px", "120px")等价,以上所有的设置高度与宽度值,都是直接设置的元素的"style"的“height”与“width”值,所以可以使用像 “100%”、“20%”等的css方式的值,含义也是与css的一样。

       Window.getClientHeight() //浏览器客户区的高度,单位像素
       Window.getClientWidth() //浏览器的客户区的宽度,单位像素
          注:这两个函数在ie与firefox中不一样,在ie中不包含浏览器的滚动条,而在firefox中是包含的。浏览器出现滚动条,假设滚动条宽度为15px,全屏,屏幕分辨率为1024*768,
    ie中:Window.getClientWidth()的值大概为1024-15 ,实际上比这个值要小一点
    firefox中:Window.getClientWidth()的值为1024

    例如:

                TextBox text  =   new  TextBox();
                text.setPixelSize(
100 120 );
                int h = text.getOffsetHeight()
;
                int w = text.getOffsetWidth()
;
                Window.alert("h:"+h+" w:"+w);

    上面的四行代码是连续的,那么h与w的值等于多少呢,想一想再看下面的结果


都为零

先到这里吧,关于高度与宽度的问题还有一些。
2,对话框居中
    gwt1.2.22都没有提供对话框居中的直接方法,在这里说一下可能的实现方法
    一,直接设定大小
        DialogBox d = new DialogBox();
        d.setText("DialogBox");
        d.setPixelSize(100, 120);      //要指定大小,操作起来不通用
        int x = (Window.getClientWidth()-100)/2;
        int y = (Window.getClientHeight()-120)/2;
        d.setPopupPosition(x, y);
        d.show();
      
    二,延迟实现
       final DialogBox d = new DialogBox();
        d.setText("DialogBox");
        DeferredCommand.add(new Command(){   //延迟执行,
            public void execute()
            {
                int x = (Window.getClientWidth()-d.getOffsetWidth())/2;
                int y = (Window.getClientHeight()-d.getOffsetHeight())/2;
                d.setPopupPosition(x, y);
            }
        });
        d.show();
       注:“延迟执行”因为对话在刚创建时,它的高度与宽度还没有,所以一定要延迟一下,再取它的高度与宽度来计算它的居中位置。
    三,继承实现
       DialogBox d = new DialogBox(){
            protected void onLoad()   //对话装载完成后执行的函数
            {
                super.onLoad();
                int x = (Window.getClientWidth()-getOffsetWidth())/2;
                int y = (Window.getClientHeight()-getOffsetHeight())/2;
                setPopupPosition(x, y);
            }
        };
        d.setText("DialogBox");
        d.show();
    我知道的就这些,如果还有别的方法,希望给我讲一下,我再把它们加上来

1,jsp中可以关闭一个页面而到另一个页面,那么在gwt中怎么解决呢?其实在gwt中只有一个页面,要实现“关闭”的功能是这样的
    RootPanel.get().clear();//取得根panel(对应html中的body体),清除它的所有子对象,就是把整个页面的内容“关闭”,然后就可以再加入自己的新的内容。
  这里也可以清除指它的对象(widget):
    RootPanel.get().remove(w); //w为Widget
    DOM.removeChild(RootPanel.getBodyElement(), w.getElement());//与上一句的功能一样,DOM类中有很多比较好用的静态方法,具体的就看gwt的文档。
举一个例子:“关闭登录窗口转到主窗口”
    //成功登录
    RootPanel.get().clear();//也可以 RootPanel.get().remove(login);
    RootPanel.get().add(mainView);//mainView主页面

 

引用---http://www.java125.cn/trackback.asp?tbID=1135

分享到:
评论

相关推荐

    GWT开发教程.pdf

    一旦插件安装完成,你可以开始创建一个新的GWT项目。项目初始化时,会生成一个默认的入口点类和配置文件。但为了自定义你的应用,通常需要删除这些默认生成的代码和配置。例如,你需要从`web.xml`文件中移除与`...

    GWT入门 GWT中文教程

    “GWT快速开发”这部分教程则专注于提高开发效率,可能包含了GWT的开发工具、IDE集成、代码生成、调试技巧等内容,让开发者能快速上手并高效地进行GWT项目开发。 “GWT入门”和“GWT中文教程”显然是针对初学者的,...

    面向 Java 开发人员的 Ajax: Google Web Toolkit 入门(GWT入门)

    使用Eclipse或IntelliJ IDEA等集成开发环境(IDE)可以方便地创建和管理GWT项目。 2. **创建第一个GWT应用**: 通过IDE创建一个新的GWT模块,编写简单的Hello World程序,了解基本的Widget使用和布局管理。 3. **理解...

    gwt学习资料和实例项目

    **Java和GWT应用开发.pdf** 这本书籍或文档可能详细介绍了如何使用Java与GWT进行应用程序开发。通常,它会涵盖GWT的基础知识,包括GWT的架构、开发环境的设置、UI组件的使用、事件处理、数据绑定、RPC通信、模块系统...

    gwt in practice gwt快速开发

    《GWT in Practice》这本书可能是关于如何有效地使用GWT进行实际项目开发的指南。书名中的 "Practice" 暗示了它将提供实用技巧、最佳实践和深入的实战经验,帮助开发者避免常见问题,提升开发效率。 标签 "gwt in ...

    smartGWT开发环境搭建(完整工程)

    安装GWT插件后,你需要创建一个新的GWT项目。在Eclipse中选择"File" &gt; "New" &gt; "Other",然后在打开的对话框中展开"Google"节点,选择"Web Application Project",点击"Next"。在新项目向导中,为项目命名,选择项目...

    基于Maven的SmartGWT项目示例

    在"基于Maven的SmartGWT项目示例"教程中,你将学习如何设置和运行这个项目,以及如何使用SmartGWT组件来构建用户界面。此外,还会了解到如何利用Maven的命令行工具进行编译、测试和部署。通过实践这个项目,开发者...

    gwt-2.5.0库

    **GWT(Google Web Toolkit)** 是一个由Google开发的...虽然现代Web开发可能转向了React、Vue.js或Angular等框架,但GWT在某些场景下,尤其是需要利用Java后端服务和已有Java代码基础的项目中,仍然具有其独特的价值。

    GWT入门教程

    首先,你需要安装GWT SDK,并使用Eclipse或IntelliJ IDEA等IDE创建一个新的GWT项目。在项目中,你会看到几个重要的目录和文件,如`src/main/java`(存放Java源代码)、`src/main/resources`(存放资源文件)以及`war...

    GWT完整教程,Word版

    在这个阶段,你会学习如何创建第一个GWT项目,理解模块化系统,以及如何利用GWT的UI组件库(如TextBox、Button等)构建用户界面。此外,还会介绍事件处理机制、数据绑定和异步通信(RPC)的基础知识。 **中级GWT....

    GWT入门教程的好东西啊

    - **创建项目**:在IDE中创建新的GWT项目,并配置好相关的SDK路径。 - **编写Java代码**:根据需求编写Java代码,利用GWT提供的API来构建UI界面和处理逻辑。 - **运行项目**:在浏览器中预览项目,测试其功能是否...

    idea编译gwt完整包含截图为接手老项目的朋友提供帮助

    4. **检查POM.xml**:GWT项目通常依赖于Maven或Gradle进行构建。检查`pom.xml`文件,确保所有依赖和插件都是最新且适用的。某些团队可能使用了生成Bean的插件,例如`gwt-maven-plugin`或`apt-maven-plugin`,确保...

    Ext-Gwt(GWT)开发实例(整合Spring +Hibernate)

    标题 "Ext-Gwt(GWT)开发实例(整合Spring +Hibernate)" 涉及到的是一个实际项目开发的教程,其中结合了三个重要的技术框架:Google Web Toolkit (GWT),Spring 和 Hibernate。这个实例旨在展示如何在Web应用开发中...

    GWT EXT 教程全集

    GWT是Google推出的一个用于开发富互联网应用程序(RIA)的开放源代码框架,它允许开发者使用Java语言编写客户端应用,然后自动编译成JavaScript。EXT-GWT则是基于GWT的组件库,提供了丰富的用户界面元素,让开发者...

    gwt java ajax programming source code

    描述中的内容简洁,但我们可以推测,这个压缩包可能包含了某个教程或项目中关于如何使用GWT、Java和Ajax进行编程的源代码示例。这些源代码可能是按照章节或主题组织的,以便学习者逐步理解并实践相关技术。 标签 ...

    gwt 服务器端(内含配置教程)

    3. **配置项目结构**:GWT项目通常包含`src/main/java`和`src/main/resources`等目录,用于存放Java源代码和资源文件。你还需要配置`war`目录,这是Web应用的根目录,包含HTML、CSS、JavaScript以及GWT编译后的输出...

    GWT开发资料合集

    首先,"入门GWT.pdf"提供了GWT的基础知识,包括GWT的基本概念、工作原理以及如何搭建第一个GWT项目。这份文档通常会介绍GWT的核心组件,如Widget库、Event Bus、History机制和RPC服务,还会讲述如何使用GWT IDE和...

    GWT

    标题 "GWT" 指的是 Google Web Toolkit,这是一个开源的Java开发框架,主要用于构建高性能、跨浏览器的富互联网应用程序(Rich Internet Applications,简称RIA)。GWT通过将Java代码编译为JavaScript,使得开发者...

Global site tag (gtag.js) - Google Analytics