SlideShare a Scribd company logo
intro
Manuel Carrasco Moñino 
Vaadin: Senior GWT Expert 
GWT: Oficial maintainer 
Apache: PMC James 
Jenkins: Committer 
manolo@vaadin.com 
http://manolocarrasco.es 
@dodotis
What is Vaadin?
Vaadin codemotion 2014
java html
for 
HTML5 apps 
Java API
Rich 
UX 
Developer 
Productivity
12Key Rich 
Components 
Idea3s 
Server 
Java
Fast development 
Good looking apps
Server side centric 
But easy to extend client side
Backend 
server 
Web 
server 
Handled by Vaadin 
commu-nications 
Browser 
50% less code
UI Components 
Rich widget collection
User Interface 
Components 
Data Sources
Any Device 
Don’t worry about vendors, resolutions …
Vaadin codemotion 2014
Powerful theme builder
Vaadin codemotion 2014
Scalable Icons 
- Based on fonts 
- No images to download
Vaadin codemotion 2014
Apache 2.0 
- No hooks 
- Big community
40% of Fortune 100 companies use Vaadin 
#2 Java Web Framework 
#2 according to Open HUB stats 
#3 according with Rebel-labs 
130k+ active developers
Show me the code
Vaadin codemotion 2014
Vaadin codemotion 2014
• name=”Marcus” 
• button clicked 
261 bytes
Vaadin codemotion 2014
• name=”Marcus 
• button clicked 
261 bytes 
• Add notification 
267 bytes
Enough talk. 
Let's build an app!
What kind of sorcery is this?
Architecture
Vaadin codemotion 2014
Vaadin codemotion 2014
Vaadin codemotion 2014
Vaadin codemotion 2014
Vaadin codemotion 2014
★ Initial HTML 
★ CSS (theme) 
★ JavaScript 
1M total 
307k 
compress 
135k 
reduced 
widgetset 
All widgets are downloaded and cached once
Browser 
Server 
onStateChanged(evt) 
caption = "Click me" 
dirty = true 
VButton 
rpc.click() ButtonConnector 
Button setCaption("Click me") 
<button clicked> 
click() 
ButtonState 
RPC
Entity 
Field 
Collection 
InMemory, Bean, 
Method, Collection, 
JDBC, JPA, 
Hibernate, TextFile, 
FileSystem, 
Properties, 
EclipseLink, Lucene, 
Mockups, GAE, ...
But wait, there's more!
All of Java 
- tooling & ecosystem 
maven, gradle, Ant, IDE’s, Junit … 
- any language in the JVM: 
java x-8, scala, groovy, jruby … 
- any Java container 
Jetty, Tomcat, GAE … 
- any Java technology 
JEE, Spring, OSGi
Built in security 
- State in server side 
- Integrity, Availability, Authenticity 
- No REST services exposed 
- Cross-Site Scripting protected 
- Request Forgery protection
Works in 
all browsers 
all devices 
> no plugins required 
> no SDK’s
6/7 8 
IE 6/7 Safari Opera IE 8 
6/7 8 
14% 18% 36% 54% 
98.1% 
3.5 Browsers to support in 2012 
3.5 Browsers to support in 2012 
IE 6/7 Safari Opera IE 8 
14% 18% 36% 54% 
What kind of devices does your app support? 
36.1% 
Desktop 
browsers 
Tablets 
Browsers developers expect to support in 2013 
Chrome 
9 10 
IE 9 IE 10 Firefox 
79% 80% 94% 94% 
Browsers developers expect to support in 2013 
Chrome 
9 10 
IE 9 IE 10 Firefox 
79% 80% 94% 94% 
does your app support? 
Phones 
25.7% 
36.1% 
Others 
2.1% 
“Since gwt in the enterprise, explain why tablets popular than support phones” 
Daniel 
iPhone 
Android 
WP 
application over 98% of apps 
had overtaken 
UI for 
US, Europe. 
the number 
36.1% 
“Since gwt is used extensively 
in the enterprise, this may 
explain why tablets are popular than support phones” 
iPad 
Android 
Windows 
+ 
+
Responsive layouts
Vaadin codemotion 2014
OR
Server push
@Push 
public class VaadinUI extends UI { 
... 
} 
ui.access(() -> Notification.show("Alert!"));
Stable API
/** 
* Creates a new push button with click listener. 
* 
* Parameters: caption - Button caption 
* listener - Button click listener 
*/ 
public Button(java.lang.String caption, 
Button.ClickListener listener) 
Millstone 3, 2002 
Vaadin 7, 2014 
/** 
* Creates a new push button with click listener. 
* 
* Parameters: caption - Button caption 
* listener - Button click listener 
*/ 
public Button(java.lang.String caption, 
Button.ClickListener listener)
GWT and JS components 
- Write Java and let GWT compile to JS 
- Wrap JS code in GWT 
- Reuse JS from server side
Extendable 
- Over 500 public Add-ons
Vaadin codemotion 2014
Getting started
Download for Free 
vaadin.com/book 
952-93-1970-1 
728 pages 
9789529319701 
PDF, ePub, HTML
Eclipse 
Download plugin 
from Martketplace
IntelliJ IDEA 
Built-in support
Netbeans 
Download plugin 
Netbeans Plugin Portal
Maven 
mvn archetype:generate 
-DarchetypeGroupId=com.vaadin 
-DarchetypeArtifactId=vaadin-archetype-application 
-DarchetypeVersion=7.3.3 
mvn vaadin:compile 
mvn jetty:run
Manuel Carrasco Moñino - manolo@vaadin.com

More Related Content

What's hot (20)

PDF
Build a REST API for your Mobile Apps using Node.js
Stormpath
 
PDF
Intro firebase
Mandy Pao
 
PDF
Understanding meteor
M A Hossain Tonu
 
ODP
code-camp-meteor
meghna gogna
 
PDF
The A1 by Christian John Felix
DEVCON
 
PDF
KKBOX WWDC17 Security - Antony
Liyao Chen
 
PPTX
ASP.NET Core 1.0 Overview: Pre-RC2
Shahed Chowdhuri
 
PPTX
ZZ BC#8 Hello ASP.NET MVC 4 (dks)
Chalermpon Areepong
 
PPTX
Capture the Cloud with Azure
Shahed Chowdhuri
 
PDF
JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...
JSFestUA
 
PDF
O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...
NCCOMMS
 
PPT
Microsoft Tech Ed 2006 #1
Jetsada Phantharangsee
 
PPT
Microsoft Tech Ed 2006 #2
Jetsada Phantharangsee
 
PPTX
Mulesoft Salesforce Connector - OAuth 2.0 JWT Bearer
Vince Soliza
 
PPTX
Selenium Topic 2 IDE
ITProfessional Academy
 
PDF
iOSDevCamp Firebase Overview
James Daniels
 
PDF
SPUnite17 Who Are You and What Do You Want
NCCOMMS
 
KEY
Getting started with Selenium 2
Sebastiano Armeli
 
PPTX
ASP.NET 5 Overview for Apex Systems
Shahed Chowdhuri
 
PDF
Introducing Firebase by Google
Algiers Tech Meetup
 
Build a REST API for your Mobile Apps using Node.js
Stormpath
 
Intro firebase
Mandy Pao
 
Understanding meteor
M A Hossain Tonu
 
code-camp-meteor
meghna gogna
 
The A1 by Christian John Felix
DEVCON
 
KKBOX WWDC17 Security - Antony
Liyao Chen
 
ASP.NET Core 1.0 Overview: Pre-RC2
Shahed Chowdhuri
 
ZZ BC#8 Hello ASP.NET MVC 4 (dks)
Chalermpon Areepong
 
Capture the Cloud with Azure
Shahed Chowdhuri
 
JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...
JSFestUA
 
O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...
NCCOMMS
 
Microsoft Tech Ed 2006 #1
Jetsada Phantharangsee
 
Microsoft Tech Ed 2006 #2
Jetsada Phantharangsee
 
Mulesoft Salesforce Connector - OAuth 2.0 JWT Bearer
Vince Soliza
 
Selenium Topic 2 IDE
ITProfessional Academy
 
iOSDevCamp Firebase Overview
James Daniels
 
SPUnite17 Who Are You and What Do You Want
NCCOMMS
 
Getting started with Selenium 2
Sebastiano Armeli
 
ASP.NET 5 Overview for Apex Systems
Shahed Chowdhuri
 
Introducing Firebase by Google
Algiers Tech Meetup
 

Similar to Vaadin codemotion 2014 (20)

PDF
Rock Your Web Apps with Vaadin: Coding Serbia 2014
Ville Ingman
 
PDF
Vaadin Introduction, 7.3 edition
Joonas Lehtinen
 
PDF
Vaadin intro at GWT.create conference
Joonas Lehtinen
 
PDF
Introduction to Vaadin
netomi
 
PDF
Javantura Zagreb 2014 - Vaadin - Peter Lehto
HUJAK - Hrvatska udruga Java korisnika / Croatian Java User Association
 
PDF
Rapid and Reliable Developing with HTML5 & GWT
Manuel Carrasco Moñino
 
PDF
Introduction to Vaadin, GWT.create 2015
hezamu
 
PPTX
GWT HJUG Presentation
Derrick Bowen
 
PDF
GWT Reloaded
Marcin Szałomski
 
PDF
The Java alternative to Javascript
Manuel Carrasco Moñino
 
PDF
Dmitriy Mustafin (HYS Enterprise) "Web UI for Back-end developer."
HYS Enterprise
 
PDF
Building i pad apps in pure java with vaadin
Joonas Lehtinen
 
PDF
Vaadin - Rich Web Applications in Server-side Java without Plug-ins or JavaSc...
Joonas Lehtinen
 
PDF
Introduction to Vaadin Framework
Risto Yrjänä
 
PDF
Vaadin, Rich Web Apps in Server-Side Java without Plug-ins or JavaScript: Joo...
jaxconf
 
PDF
Introduction to Web application development with Vaadin 7.1 - Tzukanov
Codemotion
 
PDF
Vaadin codemotion2014rome
mtzukanov
 
PDF
Javascript as a target language - GWT kickoff - part1/2
JooinK
 
PPT
Gwt training presentation
MUFIX Community
 
PDF
Vaadin and Spring at Devoxx UK 2015
Sami Ekblad
 
Rock Your Web Apps with Vaadin: Coding Serbia 2014
Ville Ingman
 
Vaadin Introduction, 7.3 edition
Joonas Lehtinen
 
Vaadin intro at GWT.create conference
Joonas Lehtinen
 
Introduction to Vaadin
netomi
 
Rapid and Reliable Developing with HTML5 & GWT
Manuel Carrasco Moñino
 
Introduction to Vaadin, GWT.create 2015
hezamu
 
GWT HJUG Presentation
Derrick Bowen
 
GWT Reloaded
Marcin Szałomski
 
The Java alternative to Javascript
Manuel Carrasco Moñino
 
Dmitriy Mustafin (HYS Enterprise) "Web UI for Back-end developer."
HYS Enterprise
 
Building i pad apps in pure java with vaadin
Joonas Lehtinen
 
Vaadin - Rich Web Applications in Server-side Java without Plug-ins or JavaSc...
Joonas Lehtinen
 
Introduction to Vaadin Framework
Risto Yrjänä
 
Vaadin, Rich Web Apps in Server-Side Java without Plug-ins or JavaScript: Joo...
jaxconf
 
Introduction to Web application development with Vaadin 7.1 - Tzukanov
Codemotion
 
Vaadin codemotion2014rome
mtzukanov
 
Javascript as a target language - GWT kickoff - part1/2
JooinK
 
Gwt training presentation
MUFIX Community
 
Vaadin and Spring at Devoxx UK 2015
Sami Ekblad
 
Ad

More from Manuel Carrasco Moñino (20)

PDF
GWT and PWA
Manuel Carrasco Moñino
 
PDF
Present and Future of GWT from a developer perspective
Manuel Carrasco Moñino
 
PDF
GWT Contributor Workshop
Manuel Carrasco Moñino
 
PDF
CRUD with Polymer 2.0
Manuel Carrasco Moñino
 
PDF
Web Components and PWA
Manuel Carrasco Moñino
 
PPTX
Building Components for Business Apps
Manuel Carrasco Moñino
 
PPTX
Web Components the best marriage for a PWA
Manuel Carrasco Moñino
 
PDF
Intro to Web Components, Polymer & Vaadin Elements
Manuel Carrasco Moñino
 
PDF
Rock GWT UI's with Polymer Elements
Manuel Carrasco Moñino
 
PDF
Introducing GWT Polymer (vaadin)
Manuel Carrasco Moñino
 
PDF
Speed up your GWT coding with gQuery
Manuel Carrasco Moñino
 
PDF
GwtQuery the perfect companion for GWT, GWT.create 2013
Manuel Carrasco Moñino
 
PDF
Aprendiendo GWT
Manuel Carrasco Moñino
 
PDF
GQuery a jQuery clone for Gwt, RivieraDev 2011
Manuel Carrasco Moñino
 
PDF
Apache James/Hupa & GWT
Manuel Carrasco Moñino
 
PDF
GWT: Why GWT, GQuery, and RequestFactory
Manuel Carrasco Moñino
 
PDF
Mod security
Manuel Carrasco Moñino
 
PDF
Gwt IV -mvp
Manuel Carrasco Moñino
 
PDF
Gwt III - Avanzado
Manuel Carrasco Moñino
 
PDF
Gwt II - trabajando con gwt
Manuel Carrasco Moñino
 
Present and Future of GWT from a developer perspective
Manuel Carrasco Moñino
 
GWT Contributor Workshop
Manuel Carrasco Moñino
 
CRUD with Polymer 2.0
Manuel Carrasco Moñino
 
Web Components and PWA
Manuel Carrasco Moñino
 
Building Components for Business Apps
Manuel Carrasco Moñino
 
Web Components the best marriage for a PWA
Manuel Carrasco Moñino
 
Intro to Web Components, Polymer & Vaadin Elements
Manuel Carrasco Moñino
 
Rock GWT UI's with Polymer Elements
Manuel Carrasco Moñino
 
Introducing GWT Polymer (vaadin)
Manuel Carrasco Moñino
 
Speed up your GWT coding with gQuery
Manuel Carrasco Moñino
 
GwtQuery the perfect companion for GWT, GWT.create 2013
Manuel Carrasco Moñino
 
Aprendiendo GWT
Manuel Carrasco Moñino
 
GQuery a jQuery clone for Gwt, RivieraDev 2011
Manuel Carrasco Moñino
 
Apache James/Hupa & GWT
Manuel Carrasco Moñino
 
GWT: Why GWT, GQuery, and RequestFactory
Manuel Carrasco Moñino
 
Gwt III - Avanzado
Manuel Carrasco Moñino
 
Gwt II - trabajando con gwt
Manuel Carrasco Moñino
 
Ad

Recently uploaded (20)

PPTX
sajflsajfljsdfljslfjslfsdfas;fdsfksadfjlsdflkjslgfs;lfjlsajfl;sajfasfd.pptx
theknightme
 
PPTX
本科硕士学历佛罗里达大学毕业证(UF毕业证书)24小时在线办理
Taqyea
 
PPT
Computer Securityyyyyyyy - Chapter 2.ppt
SolomonSB
 
PPTX
ONLINE BIRTH CERTIFICATE APPLICATION SYSYTEM PPT.pptx
ShyamasreeDutta
 
PPTX
internet básico presentacion es una red global
70965857
 
PDF
Web Hosting for Shopify WooCommerce etc.
Harry_Phoneix Harry_Phoneix
 
PPTX
法国巴黎第二大学本科毕业证{Paris 2学费发票Paris 2成绩单}办理方法
Taqyea
 
PDF
AI_MOD_1.pdf artificial intelligence notes
shreyarrce
 
PPT
introductio to computers by arthur janry
RamananMuthukrishnan
 
PPT
introduction to networking with basics coverage
RamananMuthukrishnan
 
PPTX
英国假毕业证诺森比亚大学成绩单GPA修改UNN学生卡网上可查学历成绩单
Taqyea
 
PPTX
Lec15_Mutability Immutability-converted.pptx
khanjahanzaib1
 
PPT
Computer Securityyyyyyyy - Chapter 1.ppt
SolomonSB
 
PPTX
Cost_of_Quality_Presentation_Software_Engineering.pptx
farispalayi
 
PPTX
Orchestrating things in Angular application
Peter Abraham
 
PDF
Apple_Environmental_Progress_Report_2025.pdf
yiukwong
 
PDF
DevOps Design for different deployment options
henrymails
 
PPTX
一比一原版(SUNY-Albany毕业证)纽约州立大学奥尔巴尼分校毕业证如何办理
Taqyea
 
PPTX
Presentation3gsgsgsgsdfgadgsfgfgsfgagsfgsfgzfdgsdgs.pptx
SUB03
 
PDF
Build Fast, Scale Faster: Milvus vs. Zilliz Cloud for Production-Ready AI
Zilliz
 
sajflsajfljsdfljslfjslfsdfas;fdsfksadfjlsdflkjslgfs;lfjlsajfl;sajfasfd.pptx
theknightme
 
本科硕士学历佛罗里达大学毕业证(UF毕业证书)24小时在线办理
Taqyea
 
Computer Securityyyyyyyy - Chapter 2.ppt
SolomonSB
 
ONLINE BIRTH CERTIFICATE APPLICATION SYSYTEM PPT.pptx
ShyamasreeDutta
 
internet básico presentacion es una red global
70965857
 
Web Hosting for Shopify WooCommerce etc.
Harry_Phoneix Harry_Phoneix
 
法国巴黎第二大学本科毕业证{Paris 2学费发票Paris 2成绩单}办理方法
Taqyea
 
AI_MOD_1.pdf artificial intelligence notes
shreyarrce
 
introductio to computers by arthur janry
RamananMuthukrishnan
 
introduction to networking with basics coverage
RamananMuthukrishnan
 
英国假毕业证诺森比亚大学成绩单GPA修改UNN学生卡网上可查学历成绩单
Taqyea
 
Lec15_Mutability Immutability-converted.pptx
khanjahanzaib1
 
Computer Securityyyyyyyy - Chapter 1.ppt
SolomonSB
 
Cost_of_Quality_Presentation_Software_Engineering.pptx
farispalayi
 
Orchestrating things in Angular application
Peter Abraham
 
Apple_Environmental_Progress_Report_2025.pdf
yiukwong
 
DevOps Design for different deployment options
henrymails
 
一比一原版(SUNY-Albany毕业证)纽约州立大学奥尔巴尼分校毕业证如何办理
Taqyea
 
Presentation3gsgsgsgsdfgadgsfgfgsfgagsfgsfgzfdgsdgs.pptx
SUB03
 
Build Fast, Scale Faster: Milvus vs. Zilliz Cloud for Production-Ready AI
Zilliz
 

Vaadin codemotion 2014