SlideShare una empresa de Scribd logo
1 de 60
Descargar para leer sin conexión
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?
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 …
Powerful theme builder
Scalable Icons 
- Based on fonts 
- No images to download
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
• name=”Marcus” 
• button clicked 
261 bytes
• name=”Marcus 
• button clicked 
261 bytes 
• Add notification 
267 bytes
Enough talk. 
Let's build an app!
What kind of sorcery is this?
Architecture
★ 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
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
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

Más contenido relacionado

La actualidad más candente

La actualidad más candente (20)

Build a REST API for your Mobile Apps using Node.js
Build a REST API for your Mobile Apps using Node.jsBuild a REST API for your Mobile Apps using Node.js
Build a REST API for your Mobile Apps using Node.js
 
Intro firebase
Intro firebaseIntro firebase
Intro firebase
 
Understanding meteor
Understanding meteorUnderstanding meteor
Understanding meteor
 
code-camp-meteor
code-camp-meteorcode-camp-meteor
code-camp-meteor
 
The A1 by Christian John Felix
The A1 by Christian John FelixThe A1 by Christian John Felix
The A1 by Christian John Felix
 
KKBOX WWDC17 Security - Antony
KKBOX WWDC17 Security - AntonyKKBOX WWDC17 Security - Antony
KKBOX WWDC17 Security - Antony
 
ASP.NET Core 1.0 Overview: Pre-RC2
ASP.NET Core 1.0 Overview: Pre-RC2ASP.NET Core 1.0 Overview: Pre-RC2
ASP.NET Core 1.0 Overview: Pre-RC2
 
ZZ BC#8 Hello ASP.NET MVC 4 (dks)
ZZ BC#8 Hello ASP.NET MVC 4 (dks)ZZ BC#8 Hello ASP.NET MVC 4 (dks)
ZZ BC#8 Hello ASP.NET MVC 4 (dks)
 
Capture the Cloud with Azure
Capture the Cloud with AzureCapture the Cloud with Azure
Capture the Cloud with Azure
 
JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...
JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...
JS Fest 2018. Тимофей Лавренюк. Делаем веб приложение лучше с помощью совреме...
 
O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...
O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...
O365Con18 - Connect SharePoint Framework Solutions to API's secured with Azur...
 
Microsoft Tech Ed 2006 #1
Microsoft Tech Ed 2006 #1Microsoft Tech Ed 2006 #1
Microsoft Tech Ed 2006 #1
 
Microsoft Tech Ed 2006 #2
Microsoft Tech Ed 2006 #2Microsoft Tech Ed 2006 #2
Microsoft Tech Ed 2006 #2
 
Mulesoft Salesforce Connector - OAuth 2.0 JWT Bearer
Mulesoft Salesforce Connector -  OAuth 2.0 JWT BearerMulesoft Salesforce Connector -  OAuth 2.0 JWT Bearer
Mulesoft Salesforce Connector - OAuth 2.0 JWT Bearer
 
Selenium Topic 2 IDE
Selenium Topic 2 IDESelenium Topic 2 IDE
Selenium Topic 2 IDE
 
iOSDevCamp Firebase Overview
iOSDevCamp Firebase OverviewiOSDevCamp Firebase Overview
iOSDevCamp Firebase Overview
 
SPUnite17 Who Are You and What Do You Want
SPUnite17 Who Are You and What Do You WantSPUnite17 Who Are You and What Do You Want
SPUnite17 Who Are You and What Do You Want
 
Getting started with Selenium 2
Getting started with Selenium 2Getting started with Selenium 2
Getting started with Selenium 2
 
ASP.NET 5 Overview for Apex Systems
ASP.NET 5 Overview for Apex SystemsASP.NET 5 Overview for Apex Systems
ASP.NET 5 Overview for Apex Systems
 
Introducing Firebase by Google
Introducing Firebase by GoogleIntroducing Firebase by Google
Introducing Firebase by Google
 

Similar a Vaadin codemotion 2014

A Taste of Java ME
A Taste of Java MEA Taste of Java ME
A Taste of Java ME
wiradikusuma
 
Vaadin codemotion2014rome
Vaadin codemotion2014romeVaadin codemotion2014rome
Vaadin codemotion2014rome
mtzukanov
 
HTML5 vs Native Android: Smart Enterprises for the Future
HTML5 vs Native Android: Smart Enterprises for the FutureHTML5 vs Native Android: Smart Enterprises for the Future
HTML5 vs Native Android: Smart Enterprises for the Future
Motorola Mobility - MOTODEV
 
Netbeans65 Osum Slides
Netbeans65 Osum SlidesNetbeans65 Osum Slides
Netbeans65 Osum Slides
Abhishek Gupta
 

Similar a Vaadin codemotion 2014 (20)

A Taste of Java ME
A Taste of Java MEA Taste of Java ME
A Taste of Java ME
 
Google App Engine for Java v0.0.2
Google App Engine for Java v0.0.2Google App Engine for Java v0.0.2
Google App Engine for Java v0.0.2
 
E farming
E farmingE farming
E farming
 
StrongLoop Overview
StrongLoop OverviewStrongLoop Overview
StrongLoop Overview
 
Vaadin codemotion2014rome
Vaadin codemotion2014romeVaadin codemotion2014rome
Vaadin codemotion2014rome
 
Introduction to Web application development with Vaadin 7.1 - Tzukanov
Introduction to Web application development with Vaadin 7.1 - TzukanovIntroduction to Web application development with Vaadin 7.1 - Tzukanov
Introduction to Web application development with Vaadin 7.1 - Tzukanov
 
Android Anatomy
Android  AnatomyAndroid  Anatomy
Android Anatomy
 
PPT Companion to Android
PPT Companion to AndroidPPT Companion to Android
PPT Companion to Android
 
What is web2.0
What is web2.0What is web2.0
What is web2.0
 
Seminar Android - Pengenalan PhoneGap
Seminar Android - Pengenalan PhoneGapSeminar Android - Pengenalan PhoneGap
Seminar Android - Pengenalan PhoneGap
 
Bhavin_Resume
Bhavin_ResumeBhavin_Resume
Bhavin_Resume
 
HTML5 vs Native Android: Smart Enterprises for the Future
HTML5 vs Native Android: Smart Enterprises for the FutureHTML5 vs Native Android: Smart Enterprises for the Future
HTML5 vs Native Android: Smart Enterprises for the Future
 
Imdad resume
Imdad resumeImdad resume
Imdad resume
 
What's Next Replay - SpringSource
What's Next Replay - SpringSourceWhat's Next Replay - SpringSource
What's Next Replay - SpringSource
 
Netbeans65 Osum Slides
Netbeans65 Osum SlidesNetbeans65 Osum Slides
Netbeans65 Osum Slides
 
Slides bootcamp21
Slides bootcamp21Slides bootcamp21
Slides bootcamp21
 
WSO2Con EU 2015: Keynote - The Containerization of the Developer Workspace
WSO2Con EU 2015: Keynote - The Containerization of the Developer WorkspaceWSO2Con EU 2015: Keynote - The Containerization of the Developer Workspace
WSO2Con EU 2015: Keynote - The Containerization of the Developer Workspace
 
Vaadin intro at GWT.create conference
Vaadin intro at GWT.create conferenceVaadin intro at GWT.create conference
Vaadin intro at GWT.create conference
 
JQuery Mobile vs Appcelerator Titanium vs Sencha Touch
JQuery Mobile vs Appcelerator Titanium vs Sencha TouchJQuery Mobile vs Appcelerator Titanium vs Sencha Touch
JQuery Mobile vs Appcelerator Titanium vs Sencha Touch
 
Project report for final year project
Project report for final year projectProject report for final year project
Project report for final year project
 

Más de Manuel Carrasco Moñino

Más de Manuel Carrasco Moñino (20)

The Java alternative to Javascript
The Java alternative to JavascriptThe Java alternative to Javascript
The Java alternative to Javascript
 
GWT and PWA
GWT and PWAGWT and PWA
GWT and PWA
 
Present and Future of GWT from a developer perspective
Present and Future of GWT from a developer perspectivePresent and Future of GWT from a developer perspective
Present and Future of GWT from a developer perspective
 
GWT Contributor Workshop
GWT Contributor WorkshopGWT Contributor Workshop
GWT Contributor Workshop
 
CRUD with Polymer 2.0
CRUD with Polymer 2.0CRUD with Polymer 2.0
CRUD with Polymer 2.0
 
Web Components and PWA
Web Components and PWAWeb Components and PWA
Web Components and PWA
 
Building Components for Business Apps
Building Components for Business AppsBuilding Components for Business Apps
Building Components for Business Apps
 
Web Components the best marriage for a PWA
Web Components the best marriage for a PWAWeb Components the best marriage for a PWA
Web Components the best marriage for a PWA
 
Intro to Web Components, Polymer & Vaadin Elements
Intro to Web Components, Polymer & Vaadin ElementsIntro to Web Components, Polymer & Vaadin Elements
Intro to Web Components, Polymer & Vaadin Elements
 
Rock GWT UI's with Polymer Elements
Rock GWT UI's with Polymer ElementsRock GWT UI's with Polymer Elements
Rock GWT UI's with Polymer Elements
 
Introducing GWT Polymer (vaadin)
Introducing GWT Polymer (vaadin)Introducing GWT Polymer (vaadin)
Introducing GWT Polymer (vaadin)
 
Speed up your GWT coding with gQuery
Speed up your GWT coding with gQuerySpeed up your GWT coding with gQuery
Speed up your GWT coding with gQuery
 
GwtQuery the perfect companion for GWT, GWT.create 2013
GwtQuery the perfect companion for GWT,  GWT.create 2013GwtQuery the perfect companion for GWT,  GWT.create 2013
GwtQuery the perfect companion for GWT, GWT.create 2013
 
Rapid and Reliable Developing with HTML5 & GWT
Rapid and Reliable Developing with HTML5 & GWTRapid and Reliable Developing with HTML5 & GWT
Rapid and Reliable Developing with HTML5 & GWT
 
Aprendiendo GWT
Aprendiendo GWTAprendiendo GWT
Aprendiendo GWT
 
GQuery a jQuery clone for Gwt, RivieraDev 2011
GQuery a jQuery clone for Gwt, RivieraDev 2011GQuery a jQuery clone for Gwt, RivieraDev 2011
GQuery a jQuery clone for Gwt, RivieraDev 2011
 
Apache James/Hupa & GWT
Apache James/Hupa & GWTApache James/Hupa & GWT
Apache James/Hupa & GWT
 
GWT: Why GWT, GQuery, and RequestFactory
GWT: Why GWT, GQuery, and RequestFactoryGWT: Why GWT, GQuery, and RequestFactory
GWT: Why GWT, GQuery, and RequestFactory
 
Mod security
Mod securityMod security
Mod security
 
Gwt IV -mvp
Gwt IV -mvpGwt IV -mvp
Gwt IV -mvp
 

Último

一比一原版奥兹学院毕业证如何办理
一比一原版奥兹学院毕业证如何办理一比一原版奥兹学院毕业证如何办理
一比一原版奥兹学院毕业证如何办理
F
 
Indian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
Indian Escort in Abu DHabi 0508644382 Abu Dhabi EscortsIndian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
Indian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
Monica Sydney
 
Russian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
Russian Escort Abu Dhabi 0503464457 Abu DHabi EscortsRussian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
Russian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
Monica Sydney
 
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
ayvbos
 
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girlsRussian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
Monica Sydney
 
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdfpdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
JOHNBEBONYAP1
 
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
ydyuyu
 
Abu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
Abu Dhabi Escorts Service 0508644382 Escorts in Abu DhabiAbu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
Abu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
Monica Sydney
 

Último (20)

20240510 QFM016 Irresponsible AI Reading List April 2024.pdf
20240510 QFM016 Irresponsible AI Reading List April 2024.pdf20240510 QFM016 Irresponsible AI Reading List April 2024.pdf
20240510 QFM016 Irresponsible AI Reading List April 2024.pdf
 
一比一原版奥兹学院毕业证如何办理
一比一原版奥兹学院毕业证如何办理一比一原版奥兹学院毕业证如何办理
一比一原版奥兹学院毕业证如何办理
 
Indian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
Indian Escort in Abu DHabi 0508644382 Abu Dhabi EscortsIndian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
Indian Escort in Abu DHabi 0508644382 Abu Dhabi Escorts
 
Ballia Escorts Service Girl ^ 9332606886, WhatsApp Anytime Ballia
Ballia Escorts Service Girl ^ 9332606886, WhatsApp Anytime BalliaBallia Escorts Service Girl ^ 9332606886, WhatsApp Anytime Ballia
Ballia Escorts Service Girl ^ 9332606886, WhatsApp Anytime Ballia
 
Nagercoil Escorts Service Girl ^ 9332606886, WhatsApp Anytime Nagercoil
Nagercoil Escorts Service Girl ^ 9332606886, WhatsApp Anytime NagercoilNagercoil Escorts Service Girl ^ 9332606886, WhatsApp Anytime Nagercoil
Nagercoil Escorts Service Girl ^ 9332606886, WhatsApp Anytime Nagercoil
 
Russian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
Russian Escort Abu Dhabi 0503464457 Abu DHabi EscortsRussian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
Russian Escort Abu Dhabi 0503464457 Abu DHabi Escorts
 
Trump Diapers Over Dems t shirts Sweatshirt
Trump Diapers Over Dems t shirts SweatshirtTrump Diapers Over Dems t shirts Sweatshirt
Trump Diapers Over Dems t shirts Sweatshirt
 
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
一比一原版(Curtin毕业证书)科廷大学毕业证原件一模一样
 
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrStory Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
Story Board.pptxrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr
 
Local Call Girls in Seoni 9332606886 HOT & SEXY Models beautiful and charmin...
Local Call Girls in Seoni  9332606886 HOT & SEXY Models beautiful and charmin...Local Call Girls in Seoni  9332606886 HOT & SEXY Models beautiful and charmin...
Local Call Girls in Seoni 9332606886 HOT & SEXY Models beautiful and charmin...
 
Call girls Service in Ajman 0505086370 Ajman call girls
Call girls Service in Ajman 0505086370 Ajman call girlsCall girls Service in Ajman 0505086370 Ajman call girls
Call girls Service in Ajman 0505086370 Ajman call girls
 
Meaning of On page SEO & its process in detail.
Meaning of On page SEO & its process in detail.Meaning of On page SEO & its process in detail.
Meaning of On page SEO & its process in detail.
 
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girlsRussian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
Russian Call girls in Abu Dhabi 0508644382 Abu Dhabi Call girls
 
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdfpdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
pdfcoffee.com_business-ethics-q3m7-pdf-free.pdf
 
20240508 QFM014 Elixir Reading List April 2024.pdf
20240508 QFM014 Elixir Reading List April 2024.pdf20240508 QFM014 Elixir Reading List April 2024.pdf
20240508 QFM014 Elixir Reading List April 2024.pdf
 
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
原版制作美国爱荷华大学毕业证(iowa毕业证书)学位证网上存档可查
 
20240507 QFM013 Machine Intelligence Reading List April 2024.pdf
20240507 QFM013 Machine Intelligence Reading List April 2024.pdf20240507 QFM013 Machine Intelligence Reading List April 2024.pdf
20240507 QFM013 Machine Intelligence Reading List April 2024.pdf
 
20240509 QFM015 Engineering Leadership Reading List April 2024.pdf
20240509 QFM015 Engineering Leadership Reading List April 2024.pdf20240509 QFM015 Engineering Leadership Reading List April 2024.pdf
20240509 QFM015 Engineering Leadership Reading List April 2024.pdf
 
Best SEO Services Company in Dallas | Best SEO Agency Dallas
Best SEO Services Company in Dallas | Best SEO Agency DallasBest SEO Services Company in Dallas | Best SEO Agency Dallas
Best SEO Services Company in Dallas | Best SEO Agency Dallas
 
Abu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
Abu Dhabi Escorts Service 0508644382 Escorts in Abu DhabiAbu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
Abu Dhabi Escorts Service 0508644382 Escorts in Abu Dhabi
 

Vaadin codemotion 2014

  • 2. Manuel Carrasco Moñino Vaadin: Senior GWT Expert GWT: Oficial maintainer Apache: PMC James Jenkins: Committer manolo@vaadin.com http://manolocarrasco.es @dodotis
  • 4.
  • 6. for HTML5 apps Java API
  • 7. Rich UX Developer Productivity
  • 8. 12Key Rich Components Idea3s Server Java
  • 9. Fast development Good looking apps
  • 10. Server side centric But easy to extend client side
  • 11. Backend server Web server Handled by Vaadin commu-nications Browser 50% less code
  • 12. UI Components Rich widget collection
  • 14. Any Device Don’t worry about vendors, resolutions …
  • 15.
  • 17.
  • 18. Scalable Icons - Based on fonts - No images to download
  • 19.
  • 20. Apache 2.0 - No hooks - Big community
  • 21. 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
  • 22. Show me the code
  • 23.
  • 24.
  • 25. • name=”Marcus” • button clicked 261 bytes
  • 26.
  • 27. • name=”Marcus • button clicked 261 bytes • Add notification 267 bytes
  • 28. Enough talk. Let's build an app!
  • 29. What kind of sorcery is this?
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36. ★ Initial HTML ★ CSS (theme) ★ JavaScript 1M total 307k compress 135k reduced widgetset All widgets are downloaded and cached once
  • 37. Browser Server onStateChanged(evt) caption = "Click me" dirty = true VButton rpc.click() ButtonConnector Button setCaption("Click me") <button clicked> click() ButtonState RPC
  • 38. Entity Field Collection InMemory, Bean, Method, Collection, JDBC, JPA, Hibernate, TextFile, FileSystem, Properties, EclipseLink, Lucene, Mockups, GAE, ...
  • 40. 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
  • 41. Built in security - State in server side - Integrity, Availability, Authenticity - No REST services exposed - Cross-Site Scripting protected - Request Forgery protection
  • 42. Works in all browsers all devices > no plugins required > no SDK’s
  • 43. 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 + +
  • 45.
  • 46. OR
  • 48. @Push public class VaadinUI extends UI { ... } ui.access(() -> Notification.show("Alert!"));
  • 50. /** * 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)
  • 51. GWT and JS components - Write Java and let GWT compile to JS - Wrap JS code in GWT - Reuse JS from server side
  • 52. Extendable - Over 500 public Add-ons
  • 53.
  • 55. Download for Free vaadin.com/book 952-93-1970-1 728 pages 9789529319701 PDF, ePub, HTML
  • 56. Eclipse Download plugin from Martketplace
  • 58. Netbeans Download plugin Netbeans Plugin Portal
  • 59. Maven mvn archetype:generate -DarchetypeGroupId=com.vaadin -DarchetypeArtifactId=vaadin-archetype-application -DarchetypeVersion=7.3.3 mvn vaadin:compile mvn jetty:run
  • 60. Manuel Carrasco Moñino - manolo@vaadin.com