Vaadin - Panduan Cepat

Bab ini akan memberikan gambaran umum tentang Vaadin. Anda juga akan dapat membuat daftar keuntungan dan kerugian bekerja dengan Vaadin, setelah Anda selesai dengan bab ini.

Apa itu Vaadin?

Vaadin adalah kerangka kerja pengembangan web open source. Itu datang dengan dukungan bawaan untuk skrip Java dan AJAX. Anda juga dapat memasukkan fitur eksternal ke dalamnya menggunakan Google Web toolkit. Vaadin adalah penghemat waktu bagi pengembang karena membuat konten yang kaya di browser tanpa bantuan file markup apa pun. Semua markup dan file pendukung akan dibuat saat runtime dengan bantuan kerangka kerja Vaadin. Vaadin menggunakan Java sebagai bahasa pemrograman dan mendukung pengembangan sisi server dan sisi klien.

Keuntungan dan kerugian

Bagian ini menjelaskan tentang keuntungan dan kerugian menggunakan Vaadin di aplikasi web Anda.

Keuntungan

Vaadin menawarkan keuntungan berikut kepada para pengembangnya -

Server side programming

Vaadin dibuat menggunakan Java. Selain itu, pengembang tidak perlu menggunakan bahasa markup untuk mengembangkan halaman web. Vaadin juga menyediakan semua jenis dukungan menggunakan Google Web toolkit.

Offers multiple options

Vaadin menyediakan banyak komponen, tata letak, dan pendengar yang berbeda dibandingkan dengan teknologi web konvensional mana pun; oleh karena itu lebih disukai menggunakan Vaadin.

Entirely object oriented

Karena Vaadin berbasis Java, maka Vaadin sepenuhnya berorientasi objek. Pengembang Java dapat dengan mudah mengembangkan situs web, hanya dengan mengetahui kelas Vaadin dan penggunaannya.

Easy to learn and integrate

Vaadin menyediakan dukungan plug-in dan sangat mudah dipelajari serta diintegrasikan dengan kerangka web lain.

Kekurangan

Vaadin menawarkan kerugian berikut kepada pengembangnya -

Difficult to find skilled personnel

Vaadin adalah teknologi terkini, oleh karena itu personel yang terampil selalu sesuai permintaan dan biayanya bisa mahal. Karenanya, menemukan sumber daya yang dapat memecahkan masalah kompleks dengan Vaadin mungkin sulit.

Size of Java Script file

Bergantung pada konteksnya, ukuran file java script dinamis dapat meningkat, sehingga menuntut server yang lebih besar untuk mempertahankan aksesibilitasnya melalui internet.

No fancy User Interface

Vaadin berfokus pada bisnis. Anda tidak dapat membuat situs web mewah menggunakan Vaadin.

Scalability

Beberapa ahli merasa bahwa Vaadin tidak dapat bersaing dengan teknologi berbasis klien tipis lainnya seperti Angular.js. Karenanya Vaadin kurang skalabel dibandingkan teknologi lain yang tersedia.

Dalam bab ini kita akan belajar bagaimana mengatur lingkungan lokal untuk mengembangkan aplikasi Vaadin.

Langkah-langkah dalam Instalasi Vaadin

Anda harus mengikuti langkah-langkah yang diberikan di bawah ini untuk menginstal dan menggunakan Vaadin dalam aplikasi.

Langkah 1 - Instalasi Java 8

Vaadin menggunakan JVM. Oleh karena itu, perlu menggunakan JDK 8 untuk lingkungan pengembangan lokal Anda. Silakan merujuk ke situs web resmi Oracle untuk mengunduh dan menginstal JDK 8 atau versi yang lebih baru. Anda mungkin harus mengatur variabel lingkungan untuk JAVA agar dapat bekerja dengan baik. Untuk memverifikasi instalasi Anda di sistem operasi Windows, tekan java –version di command prompt dan sebagai keluaran akan menunjukkan versi java yang diinstal di sistem Anda.

Langkah 2 - Instalasi IDE

Anda dapat menggunakan IDE apa pun yang tersedia online. Tabel berikut memberi Anda tautan unduhan berbagai IDE.

Nama IDE Tautan Instalasi
Netbean https://netbeans.org/downloads/
Gerhana https://www.eclipse.org/downloads/
Intellij https://www.jetbrains.com/idea/download/#section=windows

Apapun IDE yang Anda gunakan, pastikan Anda menggunakan versi terbaru. Harap dicatat bahwa kami menggunakan Eclipse IDE dalam tutorial ini.

Langkah 3 - Persyaratan Server

Dalam tutorial ini, kami akan menggunakan Tomcat sebagai server aplikasi. Dalam bab ini kami akan mengkonfigurasi server Tomcat kami di sistem kami. Jika Anda menginstal Netbean versi terbaru, Anda dapat langsung menginstal Apache Tomcat bersama dengan Netbean IDE. Jika tidak, silakan unduh versi terbaru TOMCAT dari situs resminya . Simpan file Tomcat yang diekstrak di drive C Anda atau file program karena kami akan menggunakan file ini di langkah selanjutnya.

Langkah 4 - Persyaratan Klien

RichFaces adalah komponen UI. Browser internet akan bertindak sebagai klien untuk aplikasi kita. Anda dapat menggunakan peramban internet modern seperti IE, Safari, Chrome, dll

Langkah 5 - Konfigurasi Eclipse

Pergi ke Eclipse Market Place dan ketik Vaadindi bilah pencarian. Anda akan menemukan layar seperti yang ditunjukkan di bawah ini. KlikInstall tombol dan instal.

Langkah ini mungkin memakan waktu karena Eclipse perlu mengunduh semua file terkait dan menginstal yang sama dan mengkonfigurasinya dengan IDE terbaru. Setelah instalasi berhasil, Eclipse akan meminta Anda untuk memulai ulang dengan cepat karena perubahan baru hanya akan terlihat setelah Anda memulai ulang yang sama. Setelah Anda memulai ulang, sistem lokal Anda siap untuk menggunakan aplikasi Vaadin.

Di bab sebelumnya, Anda telah melihat penginstalan Vaadin di sistem lokal Anda. Dalam bab ini mari kita mulai dengan membuat aplikasi pertama kita menggunakan Vaadin. Ingatlah bahwa kami menggunakan Eclipse IDE dalam tutorial ini.

Untuk mulai membuat aplikasi pertama Anda di Vaadin, buka Eclipse IDE di sistem lokal Anda dan ikuti langkah-langkah yang diberikan di bawah ini -

Step 1 - Di File menu, Klik New lalu klik Other. Lihat tangkapan layar berikut untuk pemahaman yang lebih baik.

Step 2 - Sekarang, ketik Vaadindi kotak pencarian dan Anda dapat melihat opsi seperti yang ditunjukkan pada tangkapan layar berikut. Sekarang, pilihVaadin 8 dari opsi dan klik Next.

Step 3- Anda dapat melihat jendela dengan empat opsi seperti yang ditunjukkan di bawah ini. Pilih opsi pertama dan lanjutkan ke langkah berikutnya.

Step 4- Selanjutnya, Anda dapat melihat layar seperti yang ditunjukkan pada gambar di bawah. Berikan Id Grup dan Id Artefak dan pilih Selesai. Ini menyelesaikan proyek dan Eclipse akan membuat Vaadin untuk Anda.

Harap diperhatikan bahwa langkah ini mungkin membutuhkan waktu karena memerlukan pengaturan konfigurasi. Id artefak adalah nama proyek saat ini. Kami menamakannya sebagaiMyFirstApp.

Step 5 - Sekarang, Anda dapat menemukan struktur direktori dari proyek Vaadin otomatis seperti yang ditunjukkan di bawah ini -

Step 6- Aplikasi Vaadin pertama Anda sudah siap. Jalankan proyek di server aplikasi apa pun. Setelah siap, Anda dapat menemukan layar Anda seperti yang ditunjukkan di bawah ini -

Step 7 - Masukkan teks apa saja ke dalam kotak teks dan klik Click Metombol. Anda dapat mengamati hasilnya seperti yang ditunjukkan -

Selamat! Anda telah berhasil membuat aplikasi Vaadin pertama Anda.

Dalam bab ini, Anda akan mempelajari secara detail tentang arsitektur Vaadin. Vaadin menyediakan dua modul untuk pengembangan situs web - satu untuk sisi server dan satu lagi untuk sisi klien. Gambar yang diberikan di bawah ini mengilustrasikan seluruh lingkungan runtime kerangka Vaadin.

Anda harus memahami poin-poin berikut saat menangani konfigurasi runtime Vaadin -

  • Mesin sisi klien Vaadin digunakan untuk merender keluaran atau tindakan pengguna melalui metode HTTP dasar dan browser. Generasi blok representasi ini sepenuhnya otomatis. Anda harus membuat kode hanya di bagian belakang, semua markup akan dibuat secara otomatis.

  • Sisi server menangani bagian bisnis yang menerima permintaan berbasis acara dan menyiapkan respons untuk klien. Komunikasi antara dua tingkatan terjadi melalui protokol HTTP.

  • Adaptor Terminal menerima permintaan dan memproses hal yang sama menggunakan komponen UI sisi server, yang merupakan kelas JAVA berbasis server untuk menghasilkan respons yang akan dirender menggunakan GWT komponen lain. Ini juga disebut sebagai Vaadin Servlet API, yang memperluas properti servlet, menerima permintaan dari klien yang berbeda, dan menentukan respons pengguna.

  • Vaadin menggunakan GWT (Google Web Tool Kit) dan karenanya menghasilkan keluaran yang lebih cepat dan skalabilitas yang ditingkatkan daripada aplikasi berbasis Java Script konvensional.

  • Vaadin menggunakan JSON karena lebih cepat daripada aplikasi berbasis XML konvensional.

  • Komponen terpisah yaitu CSS dan Themedapat digunakan untuk memberikan respons sisi klien yang luar biasa. Komponen ini pada dasarnya memisahkan penampilan dari representasi.

  • Modul Data Binding menyediakan API untuk dihubungkan dan dimanipulasi dengan DB jika diperlukan.

Vaadin digunakan untuk membuat komponen antarmuka pengguna yang kaya di halaman web. Dalam bab ini, Anda akan belajar tentang berbagai komponen antarmuka pengguna yang telah diperkenalkan oleh Vaadin untuk menjaga kualitas halaman web yang baik. Bagian pertama dari bab ini membahas tentang komponen web dasar dan penggunaannya, sedangkan bagian kedua membahas tentang mengikat komponen di backend.

Komponen Lapangan

Bidang adalah komponen web yang dapat dimanipulasi pengguna melalui operasi IO. Vaadin didasarkan pada JAVA, maka di Vaadin semua komponen web memiliki kelas yang diimplementasikan bersama dengan fungsi pustaka Vaadin. Gambar yang ditampilkan di bawah ini menunjukkan bagaimana komponen bidang yang berbeda diwarisi dari kelas dasar bernamaAbstractField<T>.

Perhatikan bahwa semua modul ini mirip dengan modul dalam pengembangan UI. Di Vaadin kami memiliki kelas terpisah untuk menerapkannya masing-masing. Anda akan mempelajari hal ini secara mendetail di bab-bab selanjutnya.

Label

Label digunakan untuk menyebutkan teks yang tidak dapat diedit di halaman web. Contoh yang diberikan di bawah ini menunjukkan bagaimana menggunakan label dalam aplikasi kita. Perhatikan bahwa dalam contoh yang diberikan, kami membuat kelas JAVA dan menamakannya sebagaiLabelExam.javaantarmuka dan kami akan mengesampingkannya init() metode untuk menjalankannya.

package com.MyTutorials.MyFirstApp;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.UI;

//extending UI
public class LabelExam extends UI {
   @Override
   protected void init(VaadinRequest request) {
      final HorizontalLayout hLayout = new HorizontalLayout(); //creating a Layout
      Label l1 = new Label(" Welcome to the World of Vaadin Tutorials.");
      Label l2 = new Label("\n Happy Learning .." ,ContentMode.PREFORMATTED); // Content Mode tells JVM to interpret the String mentioned in the label. Hence label2 will be printed in next line because of “\n”.
      hLayout.addComponents(l1,l2); // adding labels to layout
      setContent(hLayout); // setting the layout as a content of the web page.
   }
   // Code to control URL
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   
   @VaadinServletConfiguration(ui = LabelExam.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Dalam contoh di atas, kami telah membuat dua label dan pada akhirnya kami telah menambahkan label itu ke tata letak kami. Anda akan mempelajari lebih lanjut tentang tata letak di bab-bab selanjutnya. ItuVaadinServlettelah diterapkan untuk mengontrol URL. Namun, dalam proyek kehidupan nyata, Anda tidak perlu mendefinisikan servlet di setiap aplikasi java karena akan saling terkait. Pilih file dan klikRun on Server dan kode yang diberikan di atas akan menghasilkan keluaran seperti yang ditunjukkan di bawah ini.

Tautan

Link berguna untuk mengimplementasikan link eksternal ke website lain. Kelas ini bekerja sama persis dengan tag hyperlink HTML. Dalam contoh yang diberikan di bawah ini, kami akan menggunakan Tautan untuk mengarahkan pengguna kami ke situs web lain tergantung pada acara yang disebutClick here. Sekarang, modifikasi fileMyUI.java kelas seperti yang ditunjukkan di bawah ini.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.ExternalResource;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Link;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      
      final HorizontalLayout hLayout = new HorizontalLayout();
      
      Link link = new Link("Click Me",new ExternalResource("https://www.tutorialspoint.com/"));
      hLayout.addComponent(link);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Dalam contoh di atas, kami telah membuat hyperlink eksternal ke situs web lain. Ini akan memberi kita output berikut di browser.

Setelah pengguna mengklik link tersebut, mereka akan diarahkan ke www.tutorialspoint.com

Bidang Teks

Bagian ini membahas tentang cara membuat kolom teks menggunakan Vaadin build in class. Untuk ini, perbarui kelas MyUI.java Anda seperti yang ditunjukkan di bawah ini.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;

import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Label;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      Label l1 = new Label("Example of TextField--\n ",ContentMode.PREFORMATTED);
      TextField text = new TextField();
      text.setValue("----");
      layout.addComponents(l1,text);
      setContent(layout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Sekarang, segarkan proyek Anda dan bersihkan membangunnya. Anda dapat mengamati output yang ditunjukkan di bawah ini di browser Anda. Ingatlah untuk memulai ulang browser Anda untuk mendapatkan perubahan terkini.

Area Teks

Bagian ini menjelaskan cara membuat area teks di browser menggunakan kelas standar Vaadin. Perhatikan kode yang diberikan di bawah ini misalnya.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;

import com.vaadin.ui.Alignment;
import com.vaadin.ui.TextArea;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      final VerticalLayout hLayout = new VerticalLayout();
      TextArea text = new TextArea();
      text.setValue(" I am the example of Text Area in Vaadin");
      hLayout.addComponent(text);
      hLayout.setComponentAlignment(text,Alignment.BOTTOM_CENTER);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Potongan kode di atas akan menghasilkan output di bawah ini di browser -

Tanggal dan waktu

package com.example.myapplication;
import java.time.LocalDate;
import java.util.Locale;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;

import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Alignment;
import com.vaadin.ui.DateField;
import com.vaadin.ui.Label;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      final VerticalLayout hLayout = new VerticalLayout();
      Label l1 = new Label("Enter today's Date\n",ContentMode.PREFORMATTED);
      DateField date = new DateField();
      date.setValue(LocalDate.now());
      date.setLocale(new Locale("en","IND"));
      hLayout.addComponents(l1,date);
      hLayout.setComponentAlignment(l1,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(date,Alignment.BOTTOM_CENTER);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {
}

Dalam contoh di atas, kami telah menggunakan fungsi tanggal standar Vaadin untuk mengisi komponen tanggal di halaman web. Kode ini akan memberi Anda output seperti yang ditunjukkan pada gambar di bawah -

Tombol

Kode yang diberikan di bawah ini akan menjelaskan cara menerapkan tombol di halaman web. Di sini, kami telah menggunakan tombol bernamaClick Me.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.ExternalResource;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Alignment;
import com.vaadin.ui.Button;

import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Link;
import com.vaadin.ui.TextArea;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      final VerticalLayout hLayout = new VerticalLayout();
      TextArea text = new TextArea();
      text.setValue("Please enter some Value");
      Button b = new Button("Click Me");
      hLayout.addComponent(text);
      hLayout.addComponent(b);
      hLayout.setComponentAlignment(text,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(b,Alignment.BOTTOM_CENTER);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Kotak Centang

Vaadin juga menyediakan kelas inbuilt untuk membuat kotak centang di halaman web. Dalam contoh di bawah ini kami akan membuat kotak centang menggunakan komponen web kaya Vaadin.

package com.example.myapplication;
import java.time.LocalDate;
import java.util.Locale;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Alignment;

import com.vaadin.ui.CheckBox;
import com.vaadin.ui.DateField;
import com.vaadin.ui.Label;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout layout = new VerticalLayout();
      final VerticalLayout hLayout = new VerticalLayout();
      Label l1 = new Label("Example of Check Box\n",ContentMode.PREFORMATTED);
      CheckBox chk1 = new CheckBox("Option1");
      CheckBox chk2 = new CheckBox("Option2");
      CheckBox chk3 = new CheckBox("Option3");
      hLayout.addComponents(l1,chk1,chk2,chk3);
      hLayout.setComponentAlignment(l1,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(chk1,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(chk2,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(chk3,Alignment.BOTTOM_CENTER);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Kode yang diberikan di atas akan menghasilkan keluaran di browser seperti yang ditunjukkan di bawah ini. Anda juga dapat membuat sejumlah kotak centang untuk pengguna. Pada bab-bab berikutnya, Anda akan mempelajari berbagai cara untuk mengisi Kotak Centang di halaman web.

Pengikatan Data

Bagian ini menjelaskan cara mengikat data dari ujung depan ke ujung belakang menggunakan Vaadin sebagai kerangka kerja. Perhatikan bahwa kode yang ditunjukkan di bawah ini mengambil input dari ujung depan dengan bidang data. Mari kita buat kelas kacang untuk mengikat bidang data. Buat kelas java dan beri nama sebagaiEmployee.java.

package com.example.myapplication;
public class EmployeeBean {
   private String name = "";
   private String Email = " ";
   public EmployeeBean() {
      super();
      // TODO Auto-generated constructor stub
   }
   public EmployeeBean(String name, String email) {
      super();
      this.name = name;
      Email = email;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      System.out.println("asdassd");
      this.name = name;
   }
   public String getEmail() {
      return Email;
   }
   public void setEmail(String email) {
      Email = email; 
   }
}

Kami harus memodifikasi MyUI.javakelas untuk mengikat bidang data kelas karyawan. Perhatikan kode berikut untuk kelas yang dimodifikasi.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.PropertyId;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.Binder;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Alignment;

import com.vaadin.ui.Button;
import com.vaadin.ui.Button.ClickEvent;
import com.vaadin.ui.CheckBox;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      EmployeeBean bean = new EmployeeBean("TutorialsPoint","[email protected]");
      Binder<EmployeeBean> binder = new Binder  <EmployeeBean>();
      final FormLayout form = new FormLayout();
      Label l1 = new Label("Please fill Below Form");
      Label labelName = new Label("Name--");
      TextField name = new TextField();
      binder.bind(name,EmployeeBean::getName,EmployeeBean::setName);
      Label labelEmail = new Label("Email---");
      TextField email = new TextField();
      binder.bind(email,EmployeeBean::getEmail,EmployeeBean::setEmail);
      Button button = new Button("Process..");
      form.addComponents(l1,labelName,name,labelEmail,email,button);
      setContent(form);
      binder.setBean(bean); //auto binding using in built method
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {
   }
}

Kode yang diberikan di atas akan menghasilkan keluaran berikut di browser.

Meja

Tabel adalah salah satu fitur Vaadin yang paling dapat digunakan. Sel tabel dapat menyertakan semua jenis data. Komponen tabel dikembangkan untuk menampilkan semua data dalam format tabel yang disusun dalam struktur baris dan kolom. Namun, karena fitur tabel rilis Vaadin 8 telah mutlak dan fitur yang sama telah dimodifikasi dengan komponen Grid. Jika Anda masih menggunakan versi Vaadin yang lebih lama, Anda bebas menggunakan tabel seperti yang ditunjukkan dalam format yang diberikan di bawah ini.

/* Create the table with a caption. */
Table table = new Table("This is my Table");
/* Define the names and data types of columns.
* The "default value" parameter is meaningless here. */

table.addContainerProperty("First Name", String.class, null);
table.addContainerProperty("Last Name", String.class, null);
table.addContainerProperty("Year", Integer.class, null);

/* Add a few items in the table. */
table.addItem(new Object[] {"Nicolaus","Copernicus",new Integer(1473)}, new Integer(1));
table.addItem(new Object[] {"Tycho", "Brahe", new Integer(1546)}, new Integer(2));
table.addItem(new Object[] {"Giordano","Bruno", new Integer(1548)}, new Integer(3));
table.addItem(new Object[] {"Galileo", "Galilei", new Integer(1564)}, new Integer(4));
table.addItem(new Object[] {"Johannes","Kepler", new Integer(1571)}, new Integer(5));
table.addItem(new Object[] {"Isaac", "Newton", new Integer(1643)}, new Integer(6));

Di bab yang akan datang GRID, Anda akan mempelajari lebih lanjut tentang pembuatan Grid dan mengisi data menggunakan yang sama.

Pohon

Komponen Pohon digunakan untuk mengisi struktur direktori di situs web. Di bagian ini, Anda akan mempelajari cara mengisi pohon di halaman web menggunakan kerangka Vaadin. Perbarui yang diperlukanMyUI kelas seperti yang ditunjukkan di bawah ini.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.ui.Component;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      VerticalLayout layout = new VerticalLayout();
      Tree<String> tree = new Tree<>();
      TreeData<String> treeData =tree.getTreeData();

      // Couple of childless root items
      treeData.addItem(null, "Option1");
      treeData.addItem("Option1", "Child1");
      treeData.addItem(null, "Option2");
      treeData.addItem("Option2", "Child2");

      // Items with hierarchy
      treeData.addItem(null, "Option3");
      treeData.addItem("Option3", "Child3");
      layout.addComponent(tree);
      setContent(layout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Potongan kode di atas akan menghasilkan keluaran berikut di browser.

Bilah Menu

Komponen Menu Bar membantu kita membuat menu di website. Ini bisa dinamis serta bisa bersarang. Temukan contoh di bawah ini di mana kita telah membuat menu bar bersarang menggunakan komponen Vaadin Menu Bar. Silakan dan ubah kelas kami seperti di bawah ini.

package com.example.myapplication;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;

import com.vaadin.ui.Component;
import com.vaadin.ui.Label;
import com.vaadin.ui.MenuBar;
import com.vaadin.ui.MenuBar.MenuItem;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      VerticalLayout layout = new VerticalLayout();
      MenuBar barmenu = new MenuBar();
      layout.addComponent(barmenu);

      // A feedback component
      final Label selection = new Label("-");
      layout.addComponent(selection);

      // Define a common menu command for all the menu items.
      MenuBar.Command mycommand = new MenuBar.Command() {
         public void menuSelected(MenuItem selectedItem) {
            selection.setValue("Ordered a " +
            selectedItem.getText() +
            " from menu.");
         }
      };
      
      // Put some items in the menu hierarchically
      MenuBar.MenuItem beverages =
      barmenu.addItem("Beverages", null, null);
      MenuBar.MenuItem hot_beverages =
      beverages.addItem("Hot", null, null);
      hot_beverages.addItem("Tea", null, mycommand);
      hot_beverages.addItem("Coffee", null, mycommand);
      MenuBar.MenuItem cold_beverages =
      beverages.addItem("Cold", null, null);
      cold_beverages.addItem("Milk", null, mycommand);
      cold_beverages.addItem("Weissbier", null, mycommand);
      
      // Another top-level item
      MenuBar.MenuItem snacks =
      barmenu.addItem("Snacks", null, null);
      snacks.addItem("Weisswurst", null, mycommand);
      snacks.addItem("Bratwurst", null, mycommand);
      snacks.addItem("Currywurst", null, mycommand);
      
      // Yet another top-level item
      MenuBar.MenuItem services =
      barmenu.addItem("Services", null, null);
      services.addItem("Car Service", null, mycommand);
      setContent(layout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Dalam contoh yang dibahas di atas, kami telah membuat menu bar bersarang. Jalankan bagian kode di atas dan Anda dapat mengamati hasilnya di browser Anda seperti yang ditunjukkan di bawah ini -

Sampai sekarang Anda telah mempelajari berbagai komponen Vaadin. Dalam bab ini, Anda akan mempelajari berbagai komponen inti yang disediakan Vaadin sebagai bagian dari pustaka. Komponen inti Vaadin ramah pengguna, mudah dimengerti dan kompatibel dengan browser modern apa pun.

Kotak kombo

Kotak kombo adalah komponen pilihan yang membantu pengguna untuk memilih dari menu drop-down dan juga membantu pengembang untuk membuat drop-down untuk bidang tertentu. Contoh yang ditunjukkan di bawah ini menjelaskan cara membuat kotak kombo. Di sini kita akan mengisi sejarah Planet menggunakan kotak kombo Vaadin.

package com.example.myapplication;
public class Planet {
   private int id;
   private String name;
   public Planet(){}
   public Planet(int i, String name){
      this.id = i;
      this.name = name;
   }
   public int getId() {
      return id;
   }
   public void setId(int id) {
      this.id = id;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name; 6. Vaadin – Core Elements
   }
}

Amati potongan kode yang ditunjukkan di bawah ini dan perbarui kelas MyUI.java sesuai.

package com.example.myapplication;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;
import com.vaadin.server.VaadinRequest;

import com.vaadin.server.VaadinServlet;
import com.vaadin.ui.ComboBox;
import com.vaadin.ui.Component;
import com.vaadin.ui.Label;
import com.vaadin.ui.MenuBar;
import com.vaadin.ui.MenuBar.MenuItem;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      
      //VerticalLayout layout = new VerticalLayout();
      // List of planets
      List<Planet> planets = new ArrayList();
      planets.add(new Planet(1, "Mercury"));
      planets.add(new Planet(2, "Venus"));
      planets.add(new Planet(3, "Earth"));
      ComboBox<Planet> select =
      new ComboBox<>("Select or Add a Planet");
      select.setItems(planets);
      
      // Use the name property for item captions
      select.setItemCaptionGenerator(Planet::getName);
      
      //layout.addComponent(select);
      setContent(select);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Kode yang diberikan di atas akan menghasilkan keluaran berikut di browser.

Menu Konteks

Menu konteks adalah fitur yang membantu pengembang untuk merepresentasikan daftar ketergantungan di browser. Namun, fitur ini sudah tidak digunakan lagi pada versi terbaru Vaadin 8. Perhatikan bahwa Anda dapat melakukan hal yang sama menggunakanMenu barpilihan. Jika Anda ingin menggunakan yang sama dalam aplikasi Anda, Anda dapat menggunakan kode seperti yang ditunjukkan di bawah ini. Perhatikan bahwa Anda perlu menginstal polimer menggunakan direktori npm dan menggunakan yang sama dalam kode html Anda.

<vaadin-context-menu>
   <template>
      <vaadin-list-box>
         <vaadin-item>First menu item</vaadin-item>
         <vaadin-item>Second menu item</vaadin-item>
      </vaadin-list-box>
   </template>
   
   <p>This paragraph has the context menu provided in the above template.</p>
   <p>Another paragraph with the context menu that can be opened with <b>right click</b> or with <b>long touch.</b></p>
</vaadin-context-menu>

Karena ini adalah tutorial berbasis Java, kami akan merekomendasikan Anda untuk menggunakan opsi bilah Menu untuk mempelajari menu Konteks Vaadin.

Pemilih Tanggal

Pemilih tanggal adalah komponen lain yang didukung Vaadin, yang membantu pengembang membuat situs web dengan cara yang mudah. Kode berikut menunjukkan cara membuat pemilih tanggal di UI Vaadin. Perhatikan bahwa ini sudah tidak digunakan lagi di versi terbaru Vaadin 8 dan oleh karena itu kita perlu menggunakan objek tanggal Java untuk mengisi bidang tanggal. Tetapi jika Anda menggunakan proyek web Vaadin, Anda masih dapat menggunakannya.

package com.TutorialsMy.myApp;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.time.LocalDate;
import java.util.Arrays;
import java.util.List;
import java.util.Locale;

import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Alignment;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.DateField;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.HorizontalSplitPanel;
import com.vaadin.ui.Label;

import com.vaadin.ui.Notification;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.Upload;
import com.vaadin.ui.Upload.Receiver;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.VerticalSplitPanel;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout hLayout = new VerticalLayout();
      Label l1 = new Label("Enter today's Date\n",ContentMode.PREFORMATTED);
      DateField date = new DateField();
      date.setValue(LocalDate.now());
      date.setLocale(new Locale("en","IND"));
      hLayout.addComponents(l1,date);
      hLayout.setComponentAlignment(l1,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(date,Alignment.BOTTOM_CENTER);
      setContent(hLayout); 
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Ketika Anda menjalankan kode yang diberikan di atas, Anda dapat menemukan output berikut seperti yang ditunjukkan di bawah ini -

Anda juga dapat menggunakan kelas pemilih tanggal Vaadin dari Java secara langsung seperti yang ditunjukkan di bawah ini yang juga akan menghasilkan hasil yang sama di browser.

DatePicker datePicker = new DatePicker();

Perhatikan bahwa untuk menggunakan kelas DatePicker, Anda perlu menggunakan Vaadin V 3.0 tetapi kami menggunakan Vaadin 8.

Kisi Data

Data grid berarti melewatkan daftar data. Kerjanya mirip dengan pohon di browser. Contoh berikut menunjukkan cara kerja kisi.

Buat kelas seperti yang ditunjukkan di bawah ini dan beri nama MyCharArray.java.

package com.TutorialsMy.myApp;
public class MyCharArray { 
   private String c;
   public String getC() {
      return c;
   }
   public void setC(String c) {
      this.c = c;
   }
   public MyCharArray(){} public MyCharArray(String ch){
      this.c = ch;
   }
}

Selanjutnya, ubah kelas MyUI.java seperti yang ditunjukkan di bawah ini -

package com.TutorialsMy.myApp;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;

import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;

import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.HorizontalSplitPanel;
import com.vaadin.ui.Label;
import com.vaadin.ui.Notification;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.Upload;
import com.vaadin.ui.Upload.Receiver;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.VerticalSplitPanel;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      VerticalLayout layout = new VerticalLayout();
      List<MyCharArray> values = Arrays.asList(
      new MyCharArray("First Value"),
      new MyCharArray("Second Value"),
      new MyCharArray("thired Value"));
      final Grid<MyCharArray> grid = new Grid<>("My Table");
      grid.setItems(values);
      grid.addColumn(MyCharArray::getC).setCaption("Value");
      layout.addComponent(grid);
      setContent(layout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Sekarang, jalankan bagian kode di atas dan Anda dapat melihat output berikut di browser.

Pisahkan Tata Letak

Vaadin menyediakan banyak alat untuk mendesain halaman web sesuai dengan pilihan pengembang. Dengan menggunakan tata letak terpisah, kami dapat menyesuaikan seluruh layar sesuai pilihan kami. Contoh berikut menunjukkan kepada Anda berbagai opsi untuk membagi tata letak menggunakan komponen inti Vaadin.

Ubah MyUI.java seperti yang ditunjukkan di bawah ini -

package com.TutorialsMy.myApp;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Arrays;
import java.util.List;

import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.HorizontalSplitPanel;
import com.vaadin.ui.Label;
import com.vaadin.ui.Notification;
import com.vaadin.ui.Panel;

import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.Upload;
import com.vaadin.ui.Upload.Receiver;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.VerticalSplitPanel;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      
      // A 400x250 pixels size layout
      Panel panel = new Panel("Split Panel example");
      Panel ex = new Panel("My Splitpanel- horizontal ");
      
      // Have a horizontal split panel as its content
      HorizontalSplitPanel hsplit = new HorizontalSplitPanel();
      hsplit.addComponent(ex);
      panel.setContent(hsplit);
      setContent(hsplit);
      
      /* Panel ex1 = new Panel("My Splitpanel- vertical ");
      // Have a horizontal split panel as its content
      VerticalSplitPanel vsplit = new VerticalSplitPanel();
      hsplit.addComponent(ex1);
      panel.setContent(vsplit);
      setContent(vsplit);*/
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Dengan cara yang sama Anda dapat membagi jendela Anda secara vertikal. Saat Anda menjalankan potongan kode di atas, ini akan menghasilkan keluaran berikut di browser.

Unggah

Konten unggahan akan membantu pengguna untuk mengunggah file ke server. Ini memiliki dua mode berbeda, mode langsung dan mode tidak langsung, dikendalikan dengan kerangka inti Vaadin. Dalam mode langsung, unggahan menampilkan kotak entri nama file dan tombol untuk memilih file. Dalam mode tidak langsung, pengguna perlu memicu unggahan menggunakan tombol unggah.

Contoh berikut menunjukkan dua mode upload ini -

IKON

Vaadin memiliki ikon bawaan yang dapat digunakan sebagai tujuan umum. Ikon-ikon ini memiliki banyak keunggulan dibandingkan gambar. Mereka mengurangi ukuran kode dan membuat kompilasi lebih cepat. Contoh berikut menunjukkan cara menggunakan ini di Vaadin.

Perbarui kelas MyUI.java Anda seperti yang ditunjukkan di bawah ini.

package com.TutorialsMy.myApp;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.Arrays;
import java.util.List;

import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Notification;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.Upload;
import com.vaadin.ui.Upload.Receiver;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      
      // A 400x250 pixels size layout
      VerticalLayout content = new VerticalLayout();
      Panel p = new Panel("Example of Vaadin Upload-");
      TextField name = new TextField("Name");
      name.setIcon(VaadinIcons.USER);
      content.addComponent(name);
      
      // Button allows specifying icon resource in constructor
      Button ok = new Button("OK", VaadinIcons.CHECK);
      content.addComponent(ok);
      setContent(content);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Potongan kode ini akan berjalan di browser dan akan menghasilkan output di bawah ini di browser -

Komponen tata letak berfungsi sebagai placeholder untuk menampung dan mewakili data di ujung depan. Dalam bab ini, kita akan belajar tentang berbagai jenis komponen tata letak VAADIN.

Tata Letak Vertikal dan Horizontal

Tata letak vertikal dan horizontal adalah tata letak berurutan yang membantu pengguna merender data secara vertikal atau horizontal. Kami telah menggunakan konsep ini dalam banyak contoh sebelumnya yang telah kami lihat hingga sekarang. Contoh berikut akan menunjukkan kepada Anda bagaimana menggunakan hal yang sama di aplikasi Vaadin.

package com.TutorialsMy.myApp;
import javax.servlet.annotation.WebServlet;
import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;
import com.vaadin.ui.Button;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      Label l1 = new Label("Your Name-\n",ContentMode.PREFORMATTED);
      Label l2 = new Label("Your Address-\n",ContentMode.PREFORMATTED);
      Label l3 = new Label("Your Postal code-\n",ContentMode.PREFORMATTED);
      final VerticalLayout vLayout = new VerticalLayout();
      final HorizontalLayout hLayout = new HorizontalLayout();
      vLayout.setDescription("This is a example of vertical layout");
      vLayout.addComponents(l1,l2,l3);;
      //hLayout.setDescription("This is example of Horizontal layout");
      // hLayout.addComponents(l1,l2,l3);
      setContent(vLayout);
      //setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Kode ini akan menghasilkan output di bawah ini di browser.

Saat kita menggunakan tata letak horizontal dan bukan vertikal, maka potongan kode yang sama akan menghasilkan keluaran di bawah ini di browser.

Kotak

Grid adalah komponen lain dari Vaadin yang digunakan pengguna untuk merepresentasikan data tabel di browser. Pada bagian ini, kita akan belajar tentang Grid dan penggunaannya.

Pertama buat kelas bernama "Orang".

package com.TutorialsMy.myApp;
public class Person {
   private String name;
   private int number;
   public Person(){}
   public Person(String string, int i) {
      
      // TODO Auto-generated constructor stub
      this.name = string;
      this.number =i;
   }
   public String getName() {
      return name;
   }
   public void setName(String name) {
      this.name = name;
   }
   public int getNumber() {
      return number;
   }
   public void setNumber(int number) {
      this.number = number;
   }
}

Sekarang, tambahkan potongan kode berikut di kelas MyUI.java -

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      HorizontalLayout hLayout = new HorizontalLayout();
      
      // Have some data
      List<Person> people = Arrays.asList(
      new Person("First Boy", 98),
      new Person("Second Boy", 99),
      new Person("Thired Boy", 57));
      
      // Create a grid bound to the list
      Grid<Person> grid = new Grid<>();
      grid.setItems(people);
      grid.addColumn(Person::getName).setCaption("Name");
      grid.addColumn(Person::getNumber).setCaption("Number in Examination");
      hLayout.addComponent(grid);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Setelah kedua langkah selesai, kompilasi dan jalankan. Anda dapat mengamati keluaran berikut di browser -

Bentuk Tata Letak

Tata letak formulir adalah komponen lain dari Vaadin yang membantu kami merepresentasikan data dalam dua format kolom yang berbeda. Ini akan terlihat seperti sebuah formulir. Di bagian ini, Anda akan mempelajari lebih lanjut tentang tata letak ini.

Edit file MyUI.java Anda seperti yang ditunjukkan di bawah ini -

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      FormLayout form = new FormLayout();
      TextField tf1 = new TextField("Name");
      tf1.setIcon(VaadinIcons.USER);
      tf1.setRequiredIndicatorVisible(true);
      form.addComponent(tf1);
      TextField tf2 = new TextField("Street address");
      tf2.setIcon(VaadinIcons.ROAD);
      form.addComponent(tf2);
      TextField tf3 = new TextField("Postal code");
      tf3.setIcon(VaadinIcons.ENVELOPE);
      form.addComponent(tf3);
      
      // normally comes from validation by Binder
      tf3.setComponentError(new UserError("Doh!"));
      setContent(form);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Ketika Anda mengkompilasi dan menjalankan kode di atas, itu akan membuat output berikut di browser -

Panel

Panel adalah wadah komponen tunggal dengan bingkai yang menguraikannya. Ini memberi lebih banyak fitur pada tata letak formulir. Dalam contoh berikut, kami akan memahami cara menggunakan panel di Vaadin.

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      HorizontalLayout layout = new HorizontalLayout();
      Panel panel = new Panel("Panel Example ");
      panel.addStyleName("mypanelexample");
      panel.setSizeUndefined(); // Shrink to fit content
      layout.addComponent(panel);
      
      // Create the content
      FormLayout content = new FormLayout();
      content.addStyleName("mypanelcontent");
      content.addComponent(new TextField("Name"));
      content.addComponent(new TextField("Password"));
      content.setSizeUndefined(); // Shrink to fit
      content.setMargin(true);
      panel.setContent(content);
      setContent(panel);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Saat Anda menjalankan potongan kode di atas, ini akan menghasilkan keluaran berikut di browser

Sub Jendela

Sub jendela adalah panel mengambang di dalam browser aktif. Ini memungkinkan pengguna untuk memisahkan konten ke jendela yang berbeda. Seperti komponen Tata Letak lainnya, ini juga dikontrol oleh kode Html Vaadin runtime. Pada contoh berikut, kita akan melihat cara kerja panel sub jendela.

Ubah kode MYUI Anda seperti yang ditunjukkan di bawah ini.

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      setContent(new Label("Sub Window"));

      // Create a sub-window and set the content
      Window subWindow = new Window("~~~~~~~~Sub-window Example~~~~~~~");
      VerticalLayout subContent = new VerticalLayout();
      subWindow.setContent(subContent);
      
      // Put some components in it
      subContent.addComponent(new Label("This is a new label inside the window"));
      subContent.addComponent(new Button("Click Me :)"));
      
      // Center it in the browser window
      subWindow.center();
      
      // Open it in the UI
      addWindow(subWindow);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Setelah Anda mengkompilasi dan menjalankan potongan kode di atas, Anda akan mendapatkan output di bawah ini di browser.

Tab-Sheet

Lembar tab adalah wadah multi-komponen yang memungkinkan peralihan antar komponen menggunakan tab. Semua tab diatur sebagai bilah tab di bagian atas lembar-tab. Kode berikut. menunjukkan kepada Anda bagaimana menggunakan Vaadin Tab-Sheet.

Harap ubah kelas MyUI.java Anda seperti yang ditunjukkan di bawah ini.

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;import com.vaadin.annotations.Theme;

import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.Button;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      TabSheet tabsheet = new TabSheet();
      VerticalLayout layout = new VerticalLayout();
      layout.addComponent(tabsheet);
      
      // Create the first tab
      VerticalLayout tab1 = new VerticalLayout();
      tab1.addComponent(new Label("Eaxmple of Train"));
      tab1.setCaption("Train");
      tabsheet.addTab(tab1).setIcon(VaadinIcons.TRAIN);;
      
      // This tab gets its caption from the component caption
      VerticalLayout tab2 = new VerticalLayout();
      tab2.addComponent(new Label("Example of Plane"));
      tab2.setCaption("Plane");
      tabsheet.addTab(tab2).setIcon(VaadinIcons.AIRPLANE);
      setContent(layout);
   } 
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Anda dapat mengamati output berikut di browser saat Anda menjalankan kode yang diberikan di atas. Perhatikan bahwa Anda dapat beralih antara kereta dan pesawat bergantung pada pilihan Anda di header tab.

Tata Letak Mutlak

Tata letak absolut memungkinkan Anda untuk menempatkan konten dalam posisi selektif dengan cara yang sewenang-wenang. Kode berikut adalah contoh penggunaan absolute.

Perbarui kelas MyUI.java seperti yang ditunjukkan di bawah ini.

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Button;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      
      // A 400x250 pixels size layout
      AbsoluteLayout layout = new AbsoluteLayout();
      layout.setWidth("400px");
      layout.setHeight("200px");
      
      // A component with coordinates for its top-left corner
      TextField text = new TextField("Example of Absolute Layout");
      layout.addComponent(text, "left: 50px; top: 50px;");
      setContent(layout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Anda dapat mengamati output berikut di browser Anda saat menjalankan kode yang diberikan di atas -

Tata Letak Kustom

Tata letak khusus adalah tata letak yang dapat Anda sesuaikan sesuai kebutuhan Anda, dan karenanya namanya. Contoh berikut menunjukkan cara membuat satu tata letak khusus untuk aplikasi kita.

Ubah kelas MyUI.java seperti yang ditunjukkan di bawah ini -

package com.TutorialsMy.myApp;
import java.util.Arrays;
import java.util.List;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.Label;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.UI;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      
      // A 400x250 pixels size layout
      Panel loginPanel = new Panel("Login");
      CustomLayout content = new CustomLayout("layoutname");
      content.setSizeUndefined();
      loginPanel.setContent(content);
      loginPanel.setSizeUndefined();
      
      // No captions for fields is they are provided in the template
      content.addComponent(new TextField(), "username");
      content.addComponent(new TextField(), "password");
      content.addComponent(new Button("Login"), "okbutton");
      
      //content.addComponent(loginPanel
      setContent(loginPanel);
      setContent(content);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Anda dapat mengamati keluaran berikut di browser Anda ketika Anda menjalankan potongan kode di atas -

Bab ini membahas secara mendetail tentang fitur Vaadin lainnya, yang dikenal sebagai Tema. Secara umum, tema berarti kerangka kerja yang dapat disesuaikan pada waktu proses. Konten akan dinamis tergantung pada respons yang diterima di ujung server.

Vaadin menyediakan antarmuka yang keren untuk menggunakan tema dengan bantuan kompiler SAAS berbasis Java-nya sendiri. Fitur tema diberikan kepada Vaadin untuk memberikan gaya dan tampilan yang dapat disesuaikan ke aplikasi. Tema adalah templat yang dibuat sebelumnya dan pengembang perlu menyesuaikannya untuk membangun aplikasi mereka sendiri yang menghemat waktu mereka.

Anda dapat menemukan semua tema di Vaadin di bawah themefolder dan setiap sub folder dapat dideskripsikan sendiri. Karenanya, sangat mudah juga untuk mengubah kode dan menyesuaikannya. Tema apa pun dapat memiliki dua jenis file CSS di dalamnya -.saas jenis dan .cssTipe. Meskipun Vaadin tidak memiliki batasan apa pun pada nama folder, selalu disarankan untuk menggunakan nama folder seperti yang Anda lihat dari gambar yang diberikan di atas.

Ada dua jenis tema yang tersedia - Inbuilt dan Custom. Bagian ini membahasnya secara rinci.

Tema Bawaan

Vaadin built in theme disediakan dengan memberi anotasi dengan nama theme seperti yang ditunjukkan di bawah ini.

@Theme("mytheme")
public class MyUI extends UI {

Semua latar belakang warna abu-abu saat menjalankan aplikasi Vaadin berasal dari inbuilt cssfile. Kita dapat mengubah file-file itu untuk menjadikannya sebagai tema khusus yang merupakan jenis tema lain. Tidak ada yang bisa kita pelajari tentang tema bawaan Vaadin. Semua komponen yang disebutkan di atas adalah bagian dari Tema Vaadin.

Tema khusus - Membuat dan Menggunakan Tema

Tema khusus ditempatkan di VAADIN/themes folder aplikasi web, dalam proyek Eclipse di bawah WebContent folder atau src/main/webappdalam proyek Maven. Lokasi ini ditetapkan dan direkomendasikan untuk tidak berubah untuk semua jenis persyaratan. Untuk menentukan tema SAAS dengan namamytheme, Anda harus menempatkan file tersebut di folder mitos di bawah folder tema, lalu membangun kembali proyek Anda. Vaadin secara otomatis akan membuat file .css-nya sendiri dengan cepat kapan pun diminta oleh browser.

Anda dapat mengubah gaya konten di file css sesuai kebutuhan Anda. Namun, ingatlah untuk membangun proyek sekali lagi dan itu akan mulai mencerminkan kemajuan.

Tema Responsif

Vaadin juga mendukung tema responsif. Halaman web responsif dapat secara otomatis mengatur ukuran font sesuai dengan ukuran layar. Di aplikasi Vaadin, kita perlu menambahkan satu baris kode agar seluruh aplikasi menjadi responsif.

Mari kita pertimbangkan contoh berikut untuk mempelajari lebih lanjut tentang Vaadin. Lakukan perubahan di kelas MyUI.java seperti yang ditunjukkan di bawah ini.

package com.TutorialsMy.myApp;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.time.LocalDate;
import java.util.Arrays;
import java.util.List;
import java.util.Locale;
import javax.servlet.annotation.WebServlet;

import com.vaadin.annotations.Theme;
import com.vaadin.annotations.VaadinServletConfiguration;
import com.vaadin.data.TreeData;
import com.vaadin.icons.VaadinIcons;
import com.vaadin.server.Responsive;
import com.vaadin.server.UserError;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinServlet;
import com.vaadin.shared.ui.ContentMode;

import com.vaadin.ui.AbsoluteLayout;
import com.vaadin.ui.Alignment;
import com.vaadin.ui.Button;
import com.vaadin.ui.CustomLayout;
import com.vaadin.ui.DateField;
import com.vaadin.ui.FormLayout;
import com.vaadin.ui.Grid;
import com.vaadin.ui.HorizontalLayout;
import com.vaadin.ui.HorizontalSplitPanel;

import com.vaadin.ui.Label;
import com.vaadin.ui.Notification;
import com.vaadin.ui.Panel;
import com.vaadin.ui.TabSheet;
import com.vaadin.ui.TextField;
import com.vaadin.ui.Tree;
import com.vaadin.ui.UI;
import com.vaadin.ui.Upload;
import com.vaadin.ui.Upload.Receiver;
import com.vaadin.ui.VerticalLayout;
import com.vaadin.ui.VerticalSplitPanel;
import com.vaadin.ui.Window;

@Theme("mytheme")
public class MyUI extends UI {
   @Override
   protected void init(VaadinRequest vaadinRequest) {
      final VerticalLayout hLayout = new VerticalLayout();
      Label l1 = new Label("Enter today's Date\n",ContentMode.PREFORMATTED);
      DateField date = new DateField();
      date.setValue(LocalDate.now());
      date.setLocale(new Locale("en","IND"));
      hLayout.addComponents(l1,date);
      hLayout.setComponentAlignment(l1,Alignment.BOTTOM_CENTER);
      hLayout.setComponentAlignment(date,Alignment.BOTTOM_CENTER);
      Responsive.makeResponsive(hLayout);
      setContent(hLayout);
   }
   @WebServlet(urlPatterns = "/*", name = "MyUIServlet", asyncSupported = true)
   @VaadinServletConfiguration(ui = MyUI.class, productionMode = false)
   public static class MyUIServlet extends VaadinServlet {}
}

Saat Anda menjalankan kode yang diberikan di atas, Anda dapat mengamati output berikut di browser.

Untuk menguji responsivitas layout, kurangi browser dan Anda dapat mengamati bahwa panel dan komponen layout akan berubah ukuran dan bentuknya.