Do you want your ad here?

Contact us to get your ad seen by thousands of users every day!

[email protected]

Your First Vaadin Spring Application in 2023

  • May 25, 2023
  • 2885 Unique Views
  • 2 min read
Table of Contents
Step 1: Set Up ProjectStep 2: Create a Simple HelloWorld ApplicationBonus: quick links to typical configurations

Spring pun intended, but I wanted to update the guide for beginners interested in combining these two technologies.

By following these steps, you'll have a basic Vaadin-Spring Boot application up and running in no time.

Recently I noticed that it is 8 years since Vaadin was first released in start.spring.io. Since then, there have been many additions to both Spring boot and Vaadin.

Recent upgrade to Java 17 and Jakarta EE 9 baseline. Vaadin 24 added a new pre-compiled frontend mode making the initial startup matter of seconds (native compilation using GraalVM would make that even faster). And many many more. Time to grow a new project.

Step 1: Set Up Project

The Spring Initializr will help us create a new Spring Boot application with the desired dependencies. Think of it as a pom.xml configurator.

  1. Open start.spring.io If this this your first time here, you can use the following setting to configure your project:
    • Project: Maven
    • Spring Boot: 3.0.6
    • Click on "Add Dependencies" and search for "Vaadin".
    • Add any other dependencies you might want for your project, like "Spring Data JPA", "Spring Security", or "JOOQ Access Layer".
    • Enter the Artifact and Group you want for your project.
    • Write a brief description for your project.
  2. Click "Generate" to download the configured project.
  3. Unzip the package and import the folder into your Integrated Development Environment (IDE) as a Maven project.

Now you have now created an empty project and are ready to start developing the User Interface (UI) and functionality.

Step 2: Create a Simple HelloWorld Application

Let's start with a simple HelloWorld application to make sure everything is working fine.

Here's a small HelloWorld.java you can use to test:

package org.vaadin.example.springapp;

import com.vaadin.flow.component.html.Div;
import com.vaadin.flow.component.ClickEvent;
import com.vaadin.flow.component.button.Button;
import com.vaadin.flow.component.notification.Notification;
import com.vaadin.flow.router.Route;

@Route("/")
public class HelloWorld extends Div {

    public HelloWorld() {
        add(new Button("Click to say hello", this::sayHello));
    }

    public void sayHello(ClickEvent<Button> e) {
        Notification.show("Hello stranger");
    }
}

To start the server, just open the context menu on the SpringAppApplication.java file and click “Run Java”. This will start the embedded web server and Vaadin in development mode.

Now that your server is running, head to http://localhost:8080/ to access your newly created Vaadin application.

The sample application above didn’t do too much, and you are likely to want to add something more. You can do this incrementally, but here are some typical setups:

That’s a-may-zing! You have just set up and run your first Vaadin application with Spring Boot. Enjoy exploring more features and functionalities of Vaadin and Spring Boot.

Do you want your ad here?

Contact us to get your ad seen by thousands of users every day!

[email protected]

Comments (0)

Highlight your code snippets using [code lang="language name"] shortcode. Just insert your code between opening and closing tag: [code lang="java"] code [/code]. Or specify another language.

No comments yet. Be the first.

Subscribe to foojay updates:

https://foojay.io/feed/
Copied to the clipboard