Google Web Toolkit

From Wikipedia, the free encyclopedia
Jump to: navigation, search
Google Web Toolkit
Gwt-logo.png
Original author(s) Google
Initial release May 16, 2006
Stable release 2.6.1 / May 10, 2014 (2014-05-10)
Written in Java
Operating system GNU/Linux, Windows, Mac OS X
Available in Java
Type Ajax framework
License Apache License 2.0
Website www.gwtproject.org

Google Web Toolkit (GWT /ˈɡwɪt/), or GWT Web Toolkit,[1] is an open source set of tools that allows web developers to create and maintain complex JavaScript front-end applications in Java. Other than a few native libraries, everything is Java source that can be built on any supported platform with the included GWT Ant build files. It is licensed under the Apache License version 2.0.[2]

GWT emphasizes reusable approaches to common web development tasks, namely asynchronous remote procedure calls, history management, bookmarking, UI abstraction, internationalization, and cross-browser portability.

History[edit]

GWT version 1.0 RC 1 was released on May 16, 2006.[3] Google announced GWT at the JavaOne conference, 2006.[4]

Release history
Release Date
GWT 1.0 May 17, 2006
GWT 1.1 August 11, 2006
GWT 1.2 November 16, 2006
GWT 1.3 February 5, 2007
GWT 1.4 August 28, 2007
GWT 1.5 August 27, 2008
GWT 1.6 April 7, 2009
GWT 1.7 July 13, 2009
GWT 2.0 December 8, 2009
GWT 2.1.0 October 19, 2010
GWT 2.2.0 February 11, 2011
GWT 2.3.0 May 3, 2011
GWT 2.4.0 September 8, 2011
GWT 2.5.0 October 2012
GWT 2.5.1 March 2013
GWT 2.6.0 January 30, 2014
GWT 2.6.1 May 10, 2014

In August 2010, Google acquired Instantiations,[5] a company known for its focus on Eclipse Java developer tools, including GWT Designer, which is now bundled with Google Plugin for Eclipse.

In 2011 with the introduction of the Dart programming language, Google has reassured the GWT community that GWT will continue to be supported for the foreseeable future, but also hinted at a possible rapprochement between the two Google solutions for "structured web programming". They've also admitted however that a number of engineers previously working on GWT are now working on Dart.[6]

In 2012 at Google I/O Google announced that GWT would be transformed from a Google project to a fully open sourced project.[7] In July 2013, Google posted on its GWT blog that the transformation to an open source project was complete.[8]

Development with GWT[edit]

Using GWT, developers can develop and debug Ajax applications in the Java language using the Java development tools of their choice. When the application is deployed, the GWT cross-compiler translates the Java application to standalone JavaScript files that are optionally obfuscated and deeply optimized. When needed, JavaScript can also be embedded directly into Java code, using Java comments.[9]

GWT does not revolve only around user interface programming; it is a general set of tools for building any sort of high-performance client-side JavaScript functionality. Indeed, many key architectural decisions are left completely to the developer. The GWT mission statement[10] clarifies the philosophical breakdown of GWT's role versus the developer's role. History is an example of such: although GWT manages history tokens as users click Back or Forward in the browser, it does not prescribe how to map history tokens to an application state.

GWT applications can be run in two modes:

  • Development mode (formerly Hosted mode): The application is run as Java bytecode within the Java Virtual Machine (JVM).[11] This mode is typically used for development, supporting hot swapping of code and debugging.
  • Production mode (formerly Web mode): The application is run as pure JavaScript and HTML, compiled from the Java source. This mode is typically used for deployment.

Several open-source plugins are available for making GWT development easier with other IDEs, including GWT4NB[12] for NetBeans, Cypal Studio for GWT[13] (an Eclipse plugin), and GWT Developer for JDeveloper. The Google Plugin for Eclipse handles most GWT related tasks in the IDE, including creating projects, invoking the GWT compiler, creating GWT launch configurations, validation, and syntax highlighting.

Components[edit]

The major GWT components include:

GWT Java-to-JavaScript Compiler
Translates the Java programming language to the JavaScript programming language.
GWT Development Mode
Allows the developers to run and execute GWT applications in development mode (the app runs as Java in the JVM without compiling to JavaScript). Prior to 2.0, GWT hosted mode provided a special-purpose "hosted browser" to debug your GWT code. In 2.0, the web page being debugged is viewed within a regular browser. Development mode is supported through the use of a native-code plugin called the Google Web Toolkit Developer Plugin for many popular browsers.
JRE emulation library
JavaScript implementations of the commonly used classes in the Java standard class library (such as most of the java.lang package classes and a subset of the java.util package classes).
GWT Web UI class library
A set of custom interfaces and classes for creating widgets.

Features[edit]

  • Dynamic and reusable UI components: programmers can use pre-designed classes to implement otherwise time-consuming dynamic behaviors, such as drag-and-drop or sophisticated visual tree structures.[14]
  • Simple RPC mechanism
  • Browser history management
  • Support for full-featured Java debugging[4]
  • GWT handles some cross-browser issues for the developer.[4]
  • Unit testing integration
  • Support for Internationalization and localization
  • HTML Canvas support (subject to API changes) [15]
  • The developers can mix handwritten JavaScript in the Java source code using the JavaScript Native Interface (JSNI).
  • Support for using Google APIs in GWT applications (initially, support for Google Gears)
  • Open-source
  • The developers can design and develop their application in a pure object-oriented fashion, since they're using Java (instead of JavaScript).[14] Common JavaScript errors, such as typos and type mismatches, are caught at compile time.
  • The JavaScript that the GWT compiler generates can be tailored to be either unobfuscated and easier to understand or obfuscated and smaller to download.[14]
  • A number of libraries are available for GWT, by Google and third parties. These extend GWT's features.[14]

Available Widgets[edit]

As of version 2.4 (September 2011), GWT offers several widgets[16] and panels.[16]

Widgets and panels
Widgets Panels
Button PopupPanel
PushButton StackPanel
RadioButton StackLayoutPanel
CheckBox HorizontalPanel
DatePicker VerticalPanel
ToggleButton FlowPanel
TextBox VerticalSplitPanel
PasswordTextBox HorizontalSplitPanel
TextArea SplitLayoutPanel
Hyperlink DockPanel
ListBox DockLayoutPanel
CellList TabPanel
MenuBar TabLayoutPanel
Tree DisclosurePanel
CellTree
SuggestBox
RichTextArea
FlexTable
Grid
CellTable
CellBrowser
TabBar
DialogBox

Many common widgets not found in the GWT have been implemented in third-party libraries, such as Sencha GXT (formerly Ext GWT), GWT Component Library, GWT-Ext, GWT Widget Library, GWTiger, Rocket GWT, Dojo, SmartGWT etc.

Enterprise Usage[edit]

GWT uses or supports Java, Apache Tomcat (or similar web container), Eclipse IDE, Internet Explorer,[17] and Internationalization and Localization. Java-based GWT RIAs can be tested using JUnit testing framework and code coverage tools. Because GWT allows compile time verification of images, CSS, and business logic, many common development defects are automatically discovered without need of the manual testing commonly required by RIAs.

Google has noted that some of its products are GWT based:[18]

Other companies using GWT are listed on the GWT Reference List.

GWT 2.0[edit]

On Dec 08, 2009 Google launched Google Web Toolkit 2.0 with Speed Tracer.[19]

Version 2.0 of GWT offers a number of new features,[20] including:

  • In-Browser Development Mode (formerly known as Out Of Process Hosted Mode, OOPHM): prior to version 2.0, hosted mode used to embed a modified browser to allow running the bytecode version of the application during development. With version 2.0, hosted mode, renamed "development mode", allows using any (supported) browser to view the page being debugged, through the use of a browser plugin. The plugin communicates with the development mode shell using TCP/IP, which allows cross platform debugging (for example, debugging in Internet Explorer on Windows from a development mode shell running on a Linux machine).
  • Code splitting: with the developer providing "split points" in the source code, the GWT compiler will be able to split the JavaScript code into several small chunks instead of one big download. This will lead to reduced application startup time as the size of the initial download is decreased.
  • Declarative User Interface: using an XML format, the new feature known as UiBinder allows the creation of user interfaces through declaration rather than code. This allows clean separation of UI construction and behavior implementation.
  • Resource bundling: the ClientBundle interface will allow resources of any nature (images, CSS, text, binary) to be bundled together and transferred in one download, resulting in fewer round-trips to the server and hence lower application latency.

Since the new development mode removed most platform-specific code, the new version will be distributed as a unique archive, instead of one per supported platform as was the case with previous versions.

Mobile[edit]

As a general framework for making web apps, GWT is also capable of being used as a framework for making mobile and tablet apps, either by making the needed widgets and animations from scratch, or by using one of the mobile frameworks for GWT. An HTML5 app written in GWT can have separate views for Tablets and Mobile phones.

Some of the most common mobile GWT libraries

See also[edit]

Other frameworks[edit]

  • GWT-Platform, an annotation based Model-View-Presenter framework for GWT
  • Errai is a GWT-based framework for building rich web applications using next-generation web technologies. Built on-top of ErraiBus, the framework provides a unified federation and RPC infrastructure with true, uniform, asynchronous messaging across the client and server.
  • SmartGWT, a GWT framework with a comprehensive widget library and server side databinding capabilities
  • Vaadin, uses GWT as a "rendering engine" on the browser side of its server-based web apps written in Java.[21]
  • Sencha GXT, GWT port of the popular Ext JS UI Framework commonly used in Enterprise applications.
  • Crux Framework is a open source GWT-based component framework for fast development of web and mobile applications.
  • Pyjamas Pyjamas, a port of GWT to Python
  • RubyJS, a port of GWT to Ruby
  • ZK, a similar framework, which is also written in Java.
  • GwtPHP, Backend for GWT in PHP.
  • Scala+GWT, compile Scala code for the browser via the GWT toolchain.
  • JavaCC, GWT compatible [22] parser generator, implement client-side (JavaScript-based) parsers in Java.

References[edit]

  1. ^ "GWT Name Use Policy". Google. Retrieved 2014-04-23. 
  2. ^ "Google Web Toolkit License Information". Google. February 23, 2007. Retrieved 2007-09-25. 
  3. ^ "Google Web Toolkit Release Archive". Google. Retrieved 2007-09-25. 
  4. ^ a b c Olson, Steven Douglas (2007). Ajax on Java. O'Reilly. p. 183. ISBN 978-0-596-10187-9. 
  5. ^ Ramsdale, Chris. "Google Relaunches Instantiations Developer Tools". 
  6. ^ "Google Web Toolkit Blog: GWT and Dart". Googlewebtoolkit.blogspot.com. 2011-11-10. Retrieved 2013-06-16. 
  7. ^ Vaadin to Support Google Web Toolkit (GWT) Development. vaadin.com (2012-06-29). Retrieved on 2014-05-15.
  8. ^ Google Web Toolkit Blog: GWT News. Googlewebtoolkit.blogspot.com (2013-07-15). Retrieved on 2014-05-15.
  9. ^ "Coding Basics - JavaScript Native Interface (JSNI) - Google Web Toolkit — Google Developers". Developers.google.com. 2012-10-25. Retrieved 2013-06-16. 
  10. ^ GWT mission statement
  11. ^ Debugging in Development Mode
  12. ^ GWT4NB
  13. ^ Cypal Studio for GWT
  14. ^ a b c d Perry, Bruce W (2007). Google Web Toolkit for Ajax. O'Reilly Short Cuts. O'Reilly. pp. 1–5. ISBN 978-0-596-51022-0. 
  15. ^ "GWT Javadoc". 
  16. ^ a b "Widget List". Google. Retrieved 2012-05-21. 
  17. ^ GWT Project. GWT Project. Retrieved on 2014-05-15.
  18. ^ "Google I/O 2012 - The History and Future of Google Web Toolkit". GoogleDevelopers. Retrieved 2013-03-18. 
  19. ^ Introducing Google Web Toolkit 2.0, now with Speed Tracer
  20. ^ "GWT 2.0 milestone 1 announcement". Amit Manjhi. Retrieved 2009-10-05. 
  21. ^ "Vaadin FAQ". Vaadin Ltd. Retrieved 2014-05-11. 
  22. ^ "Building parsers for the web with JavaCC & GWT (Part one)". Chris Ainsley. Retrieved 2014-05-04. 

Bibliography[edit]

External links[edit]