Building Full-Stack Applications in Java with Vaadin

Поделиться
HTML-код
  • Опубликовано: 1 июн 2024
  • If you want to build a full-stack application in Java you have a few options. In this tutorial I am going to show you how to build frontend apps entirely in Java using Vaadin Flow.
    🔗Resources & Links mentioned in this video:
    GitHub Repo: github.com/danvega/hello-vaadin
    👋🏻Connect with me:
    Website: www.danvega.dev
    Twitter: / therealdanvega
    Github: github.com/danvega
    LinkedIn: / danvega
    Newsletter: www.danvega.dev/newsletter
    SUBSCRIBE TO MY CHANNEL: bit.ly/2re4GH0 ❤️
  • НаукаНаука

Комментарии • 57

  • @marcushellberg13
    @marcushellberg13 4 месяца назад +7

    Thanks for another great video, Dan!
    Pro tip for creating the service at 11:44 - if you have the contents of a Java class in your clipboard, you can paste it onto the package in the IntelliJ sidebar and it'll create an appropriately named Java file with that content 🤯

  • @petmik5022
    @petmik5022 4 месяца назад +13

    I use Vaadin almost 6 years, its pity everybody use js frameworks and Vaadin only 1 percentage of devs, best framweork for me plus Hilla

    • @_Holy_Lance_
      @_Holy_Lance_ 4 месяца назад

      I have a couple of years of experience with wicket 4, vaadin reminds me of it a lot.

    •  4 месяца назад +1

      Mi too big hommie

    • @JovanKlajic
      @JovanKlajic 4 месяца назад

      Used vaadin since version 6, lately not that much. Special indeed!

    • @cbmeeks
      @cbmeeks 4 месяца назад

      @@joonaslehtinen5175 There is absolutely no misunderstanding. We were told multiple times (in emails and video conferencing) from our rep that it's $93K for 2024 if we stick with Vaadin 8. So we had to upgrade our apps to Vaadin 14 (which is EOL in 2025). I even told them multiple times that we do not even need support. We've never, not one time, ever asked Vaadin for any support. But we were told that the $93K does not even include support! We were told it's the "Extended Maintenance Plan" that only includes security updates, etc. I have all of the email chains going back 6-7 years. I'm telling you, that's what they told me on multiple occasions.

  • @nizamibudagov5832
    @nizamibudagov5832 4 месяца назад +5

    Great video, many thanks, I didn't know there is an instrument that allows BE devs to be a little bit more independent of FE

  • @TheSqdf
    @TheSqdf 4 месяца назад +1

    Been using it for years, love it!

  • @svalyavasvalyava9867
    @svalyavasvalyava9867 4 месяца назад +2

    What a wonderful tutorial, thank you infinitely ☺️

  • @ficamu2
    @ficamu2 4 месяца назад +6

    It reminded me when I used to program in Swing

    • @marcushellberg13
      @marcushellberg13 4 месяца назад +4

      The programming model is pretty similar and will definitely feel familiar if you're coming from Swing. But the architecture is completely different with Vaadin Flow creating single-page apps running in a browser.

  • @skandarsouissi7282
    @skandarsouissi7282 2 месяца назад +1

    Never used it. Now my college projects will be vaadined. Thank you for this video.

    • @DanVega
      @DanVega  2 месяца назад +1

      Glad I could help introduce you to this amazing project!

  • @sadiulhakim7814
    @sadiulhakim7814 4 месяца назад +3

    Thank you for this video. I did not know about Vaadin.

    • @DanVega
      @DanVega  4 месяца назад +1

      Vaadin is great, they also have another framework called Hilla you should checkout!

    • @sadiulhakim7814
      @sadiulhakim7814 4 месяца назад

      @@DanVega Sure. Vaadin is like Java Swing

  • @calintamas7576
    @calintamas7576 4 месяца назад +1

    Super fain Dane!
    multumesc! Esti un adevarat prof!:)

    • @unda25
      @unda25 4 месяца назад

      de ce ai scris romaneste este roman?

    • @calintamas7576
      @calintamas7576 4 месяца назад

      dada

  • @abedalrawas2656
    @abedalrawas2656 4 месяца назад +1

    I tried Vaadin before it was introduced as a spring starter and it was frustrating. Great to know it can work seamlessly with spring now!

    • @hba6018
      @hba6018 3 месяца назад

      But it's been centuries, many years, since Spring has been integrated into Vaadin 😂

  • @Poison0444
    @Poison0444 4 месяца назад

    Working with vaadin from 7 years :) So you can do miracles with it, for one specific reason, it`s stores the states on the server

  • @user-bb4cr9jl6s
    @user-bb4cr9jl6s 4 месяца назад +1

    Very interesting video, I learned interesting technology, thank you.❤

    • @DanVega
      @DanVega  4 месяца назад

      Glad you enjoyed it. Let me know if you have any questions about Vaadin

  • @andrews1318
    @andrews1318 4 месяца назад

    and now a java champion

  • @user-jj5bj6im8g
    @user-jj5bj6im8g 4 месяца назад +5

    Wow, Is Vaadin still alive? It was rather nich 10 years ago, I thought its gone like jsf

    • @marcushellberg13
      @marcushellberg13 4 месяца назад +3

      Vaadin has evolved quite a bit in those 10 years. Back then, it used GWT for widgets, now standard HTML web components. It's also more extensible if you want to create or use 3rd party components.

    • @adambickford8720
      @adambickford8720 4 месяца назад

      That was my first thought too! Not sure if I should see what ever happened to moo tools.

  • @Luisow748
    @Luisow748 4 месяца назад

    Have you ever tried spring serving a vue 3 app, calling the vue components directly from the controller without using the vue router? I built it with Inertia integration and Vite and its quite interesting. Btw, thanks for the videos. Helped me a lot.

  • @sardorbekjuraboev4752
    @sardorbekjuraboev4752 4 месяца назад +4

    Great job Very interesting. Can you tell me please what is the advantages and disadvantages compared to GWT toolkit

    • @DanVega
      @DanVega  4 месяца назад

      I would say the rich component library. I haven't used GWT in a long time, is that still be developed and maintained?

  • @souvikroy7420
    @souvikroy7420 4 месяца назад +1

    Thanks Dan. Great video. I would love to know if those UI Components are responsive. Also, how does Vaadin work with Spring Security.

    • @marcushellberg13
      @marcushellberg13 4 месяца назад

      Some components like the DatePicker and ComboBox adapt to smaller viewports on mobile devices for improved UX. The layouts are CSS flexbox-based and you can define wrapping for responsiveness. Vaadin has great Spring Security support, check out the Vaadin docs for an example on how to set it up.

    • @souvikroy7420
      @souvikroy7420 4 месяца назад

      Thanks....I will check it out.@@marcushellberg13

  • @asiphan1
    @asiphan1 4 месяца назад +1

    Thanks for the video! Can you do the same for a full stack application with front end being angular or react and backend with spring boot with authentication

    • @DanVega
      @DanVega  4 месяца назад +1

      I have done some videos on full stack Spring Boot with Vue in the past. I don't do a lot of Angular or React but I will add it to my list. Thanks for the suggestion.

  • @IKGchiller
    @IKGchiller 4 месяца назад

    vaadin is (for better or worse) a declaration of war against rest paradigms in web apps

  • @Vityoube
    @Vityoube 4 месяца назад +1

    Thanks for interesting material. The framework seems promissing (in comparison to JSF it offers pure usage of Java for UI, however I wonder if dynamicity and AJAX on the pages could be achieved on UI). If it could support Java 8, I think, many projects could adopt it

    • @DanVega
      @DanVega  4 месяца назад

      So for example I have the list of blog posts... I could have easily had a button on the page that triggered the action to load those posts. I think we need as a community to move away from Java 8 and I'm happy Vaadin and Spring have a baseline of 17.

    • @Vityoube
      @Vityoube 4 месяца назад

      @@DanVega what about situation when it is needed to dynamically reload the grid when you added the post or imagine that you did the action on the other page that affects posts? For example you made posts using some kind of API (Facebook, Twitter, whatever else) or, for example, this page with List Grid of posts must be dynamic and listen for external changes (the posts, for example, might be added though web service call, might arrive from a message queue, ESBs, whatever else). Can Vaadin fulfill such requirements?

    • @Vityoube
      @Vityoube 4 месяца назад

      Concerning Java 17 ... For new projects (especially dev ones) it is simple to migrate to Java 17. But for existing enterprise projects, that might have years or tens of years of maintenance it is always a complicated decision to move Java 17 and usually comes with many issues and workarounds

    • @konstantingromov6485
      @konstantingromov6485 4 месяца назад

      @@Vityoube there are bunch of listeners - so you can add logic to update UI (e.g. grid data on some events). Regarding update from another page not sure - there is routing concept in Vaadin. But guess you can implement subscription on backend and trigger update on UI (if it's current route). If I understood question correctly.

    • @marcushellberg13
      @marcushellberg13 4 месяца назад +1

      @@Vityoube - yes, you can do all of that with Vaadin. Most of those can be handled by adding appropriate event listeners and updating components based on that. If you want the UI to automatically update based on data from an external system through a message queue or similar, you can enable a 2-way websocket connection with a @Push annotation (check docs), that allows you to push UI updates to the browser any time.

  • @kortneykane1268
    @kortneykane1268 4 месяца назад

    I used old version of Vaadin a few years back, its quick to develop, but getting slow when the user base increased..

    • @DanVega
      @DanVega  4 месяца назад +2

      I would give it another look 🤩

    • @marcushellberg13
      @marcushellberg13 4 месяца назад

      As a server-driven framework, it will use a bit more server resources than a fully stateless framework. The main thing to keep in mind is not to save references to any large data sets in your components.
      In Dan's example, he used `grid.setItems(List)` to set the data. That's great for small data sets like this. But if you had hundreds of thousands of rows of data, you want to avoid loading them all into server memory at once. By changing the call to use `grid.setItems(query -> {})` you can page the data from your database and never keep more than about 10-20 rows of data in memory at once.
      I have a colleague who's running a popular public-facing energy price tracking site in Finland that's built with Vaadin Flow. It's very data-heavy with charts and price info. It has nearly 100k monthly visitors, often 3k+ concurrent users. It's running without a problem on a $10/month server.

  • @Muescha
    @Muescha 4 месяца назад

    It looks a little bit the same like GWT and GXT/ext-gwt (now Sencha) for me - have done this before....

    • @Muescha
      @Muescha 4 месяца назад

      Is there a old-style extjs theme available for Vaadin?

    • @marcushellberg13
      @marcushellberg13 4 месяца назад +1

      No. Instead of having many different themes out of the box, we instead have a customizable theme that you can configure with variables to match your needs.

  • @_Holy_Lance_
    @_Holy_Lance_ 4 месяца назад +2

    Great video, I prefer apache wicket.

    • @DanVega
      @DanVega  4 месяца назад +3

      What do you like about Wiket?

    • @_Holy_Lance_
      @_Holy_Lance_ 4 месяца назад

      @@DanVega It's more familiar to me than Vaadin, just that.

  • @essamal-mansouri2689
    @essamal-mansouri2689 4 месяца назад

    This seems like such a poorly designed way to enable server-side to control the frontend rendering. It feels like we're pretending to write Java when we really are actually writing HTML divs and tables. I can't see the advantage of writing all these Vaadin-specific function calls which still requires us to know how it will translate to HTML instead of just letting us write HTML directly.

    • @marcushellberg13
      @marcushellberg13 4 месяца назад

      Vaadin Flow's Java API is on a higher level of abstraction than HTML. It's not the way to go if you need full control over the DOM. But if you are ok working on a higher level of abstraction, using components instead of elements, you'll be able to build UIs faster.