To add jQuery (or any other javascript library) to a Vaadin 7 application, follow these easy steps:
-
Create a Vaadin project either using your favorite IDE or the vaadin maven archetype (or both). Create a new class that extends from
VaadinServlet
, and override theservletInitialized
method:123456789101112131415161718192021222324252627282930313233343536import
javax.servlet.ServletException;
import
com.vaadin.server.BootstrapFragmentResponse;
import
com.vaadin.server.BootstrapListener;
import
com.vaadin.server.BootstrapPageResponse;
import
com.vaadin.server.ServiceException;
import
com.vaadin.server.SessionInitEvent;
import
com.vaadin.server.SessionInitListener;
import
com.vaadin.server.VaadinServlet;
public
class
TestJqueryVaadinServlet
extends
VaadinServlet {
@Override
protected
void
servletInitialized()
throws
ServletException {
super
.servletInitialized();
getService().addSessionInitListener(
new
SessionInitListener() {
@Override
public
void
sessionInit(SessionInitEvent event)
throws
ServiceException {
event.getSession().addBootstrapListener(
new
BootstrapListener() {
@Override
public
void
modifyBootstrapPage(BootstrapPageResponse response) {
// With this code, Vaadin servlet will add the line:
//
// <script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js" />
//
// as the first line inside the document's head tag in the generated html document
response.getDocument().head().prependElement(
"script"
).attr(
"type"
,
"text/javascript"
).attr(
"src"
,
"//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"
);
}
@Override
public
void
modifyBootstrapFragment(BootstrapFragmentResponse response) {}
});
}
});
}
}
-
Add the reference to the servlet in your
web.xml
or annotate the class with the@WebServlet
annotation. -
Create your jQuery snippet and invoke it using the
JavaScript
class, for example:12345678910111213141516171819public
class
MyVaadinUI
extends
UI {
@Override
protected
void
init(VaadinRequest request) {
final
VerticalLayout layout =
new
VerticalLayout();
layout.setMargin(
true
);
setContent(layout);
Label label =
new
Label(
"This will fade-out once you click the button"
);
Button button =
new
Button(
"Hide Label"
);
button.addClickListener(
new
Button.ClickListener() {
public
void
buttonClick(ClickEvent event) {
JavaScript.getCurrent().execute(
"$('.v-label').animate({opacity: 0.0}, 3000);"
);
}
});
layout.addComponent(label);
layout.addComponent(button);
}
}
that's very useful
ReplyDeletethanks!!
ReplyDeletethanks, it helped a lot...
ReplyDeleteyou can also use the @Stylesheet and @Javascript annotations. its much simpler.
ReplyDelete@StyleSheet({
/*
* JQuery UI
*/
"vaadin://jquery/jquery-ui-1.9.2.custom/css/ui-darkness/jquery-ui-1.9.2.custom.min.css",
})
@JavaScript({
/*
* JQuery
*/
"vaadin://jquery/jquery-1.11.1.min.js",
/*
* JQuery UI
*/
"vaadin://jquery/jquery-ui-1.9.2.custom/js/jquery-ui-1.9.2.custom.min.js",
})
public class MyUI extends UI {
...
}
great
ReplyDeleteIt is amazing and wonderful to visit your site.Thanks for sharing this information,this is useful to me..Best Devops Training in pune
ReplyDeleteMicrosoft azure training in Bangalore
Power bi training in Chennai
.
This comment has been removed by the author.
ReplyDeleteI am really impressed with your efforts and really pleased to visit this post.
ReplyDeletePython Online certification training
python Training institute in Chennai
Python training institute in Bangalore
It is amazing and wonderful to visit your site.Thanks for sharing this information..
ReplyDeletejava training in chennai
java training in omr
aws training in chennai
aws training in omr
python training in chennai
python training in omr
selenium training in chennai
selenium training in omr
Thanks for sharing great information. I like your article about geek office dog.
ReplyDeletesap training in chennai
sap training in tambaram
azure training in chennai
azure training in tambaram
cyber security course in chennai
cyber security course in tambaram
ethical hacking course in chennai
ethical hacking course in tambaram
ReplyDeleteIt is amazing and wonderful to visit your site.Thanks for sharing this information
oracle training in chennai
oracle training in annanagar
oracle dba training in chennai
oracle dba training in annanagar
ccna training in chennai
ccna training in annanagar
seo training in chennai
seo training in annanagar
Good Post! it was so good to read and useful to improve my knowledge as an updated one, keep blogging. After seeing your article, I want to say that also a well-written article with some very good information which is very useful for the AWS Cloud Practitioner Online Training
ReplyDeleteThis is most informative and also this post most user-friendly and super navigation to all posts.
ReplyDeleteScan to BIM in Minnesota
Dimension Control Services in Birmingham
Plant Engineering Services in Bayern Germany
Reverse Engineering Services in Bayern Germany