Tugas: Anda perlu membuat UI untuk backend CRUD menggunakan HTML, CSS, JS, jQuery. Kami akan membuat panel admin untuk mengelola akun game online.
- Garpu dari repositori: https://github.com/CodeGymCC/project-frontend.git
- Unduh versi proyek Anda ke komputer Anda.
- Unduh Tomcat sendiri: https://tomcat.apache.org/download-90.cgi .Penting: Tomcat membutuhkan versi 9 , bukan 10.
- Konfigurasikan peluncuran aplikasi melalui Ide: Alt + Shift + F9 -> Edit Konfigurasi… -> Alt + sisipkan -> tom (di bilah pencarian) -> Lokal.
- Setelah itu, Anda perlu mengklik
CONFIGURE
dan menunjukkan di mana arsip dengan Tomcat diunduh dan dibongkar. - Di tab
Deployment
: Alt + insert -> Artefak… -> rpg:war meledak -> OK. - Di lapangan
Application context
: tinggalkan saja/
(garis miring). - Tekan
APPLY
. - Tutup jendela pengaturan.
- Luncurkan aplikasi. Untuk melakukan ini: Alt + Shift + F9 -> (nama konfigurasi, saya beri nama 'Aplikasi') -> Jalankan.
- Setelah menerapkan aplikasi, tab baru akan terbuka di browser yang dipilih selama konfigurasi. Hebat, server sudah dikonfigurasi, lalu Anda perlu bekerja dengan dua file:
<project_dir>/src/main/webapp/html/my.html
- akan ada markup dan skrip.<project_dir>/src/main/webapp/css/my.css
– ini akan menjadi gaya. Segala sesuatu tentang gaya terserah Anda, tidak ada persyaratan untuk itu.- Di markup ( my.html ) tambahkan tabel (jangan lupa berikan id) untuk menentukan nama kolom:
- #
- Nama
- Judul
- Balapan
- profesi
- Tingkat
- Hari ulang tahun
- Dilarang
- Tambahkan tag pasangan
<script>
- kami akan menulis fungsi di sini. - Fungsi pertama harus mengirim permintaan GET ke URL
"/rest/players"
- dapatkan daftarnya. Hasilnya harus ditambahkan ke tabel dari paragraf 7 (di sinilah id tabel berguna). Jika Anda melakukan semuanya dengan benar, setelah memulai ulang server, tabel dengan 4 baris akan ditampilkan di halaman Anda. Di baris pertama - nama kolom, sisanya - data yang berasal dari server. - Sekarang, diinginkan untuk menambahkan batas sel ke tabel, jika tidak, informasi umumnya tidak dapat dibaca.
- Sekarang mari beralih ke paging. Untuk ini, Anda perlu:
- Di bawah tabel, tambahkan bagian, misalnya,
<div>
di mana akan ada tombol paging. - Tambahkan fungsi yang akan mengirimkan permintaan GET ke server yang mengembalikan jumlah total akun di server. URL:
"/rest/players/count"
. - Tambahkan daftar drop-down untuk 3-4 nilai numerik, berapa banyak akun yang ditampilkan sekaligus. Angka harus antara 3 dan 20 inklusif.
- Dalam metode untuk menampilkan daftar akun (hal. 9), kami akan menambahkan perhitungan jumlah halaman yang diperlukan untuk sejumlah akun tertentu per halaman, sehingga Anda dapat melihat semua akun.
- Dalam fungsi menampilkan daftar akun, tambahkan parameter yang akan bertanggung jawab atas jumlah halaman yang akan ditampilkan. Perbaiki URL agar meneruskan "pageNumber" dan "pageSize" sebagai parameter kueri . Sekarang, saat mengubah nomor per halaman dalam daftar drop-down, jumlah akun yang diminta harus ditampilkan:
- Sekarang mari mewarnai nomor halaman saat ini, jika tidak maka akan merepotkan ...
- Mari tambahkan 2 kolom lagi ke tabel: Edit dan Hapus. Untuk setiap baris, mari tambahkan ikon yang akan bertanggung jawab untuk mengedit dan menghapus setiap entri. Anda dapat menggunakan gambar yang ada di
<project_dir>/src/main/webapp/img/
, atau menggunakan gambar Anda sendiri. - Tulis fungsi yang akan bertanggung jawab untuk menghapus akun. Untuk melakukan ini, kirim permintaan DELETE ke server di URL
"/rest/players/{id}"
. Saat mengklik gambar keranjang, panggil fungsi ini. Setelah panggilan - jangan lupa untuk memperbarui daftar akun di halaman saat ini. - Sebelum menghapus akun dengan id=23
- Setelah menghapus akun dengan id=23 . Perhatikan, tidak ada tombol, kecuali keranjang, yang ditekan.
- Sekarang tulis fungsi yang bertanggung jawab untuk mengedit akun. Saat Anda mengkliknya, mari sembunyikan tombol "Hapus", dan ubah gambar tombol "Edit" menjadi "Simpan".
- Sekarang mari tambahkan fungsionalitas untuk mengedit akun. Dengan mengklik tombol "Edit", selain mengubah gambar, Anda perlu membuat bidang dapat diedit:
- Nama
- Judul
- Balapan
- profesi
- Dilarang
- Sekarang kami akan mengirimkan perubahan dengan mengklik tombol "Simpan". Untuk melakukan ini, Anda perlu mengirim permintaan POST ke URL
“/rest/players/{id}”
dan meneruskan nilai dari kelima bidang sebagai isi permintaan, yang dapat diubah dalam bentuk JSON. Gunakan JSON.stringify({...}); Setelah perubahan, jangan lupa memuat ulang data di halaman saat ini. - Jadi, semuanya harus dilakukan dari CRUD saat ini, kecuali untuk "C" (Buat). Setelah tombol paging, tambahkan garis horizontal dan teks yang menyatakan bahwa Anda dapat membuat akun baru di sini. Selain itu, tambahkan blok teks dan kolom masukan untuk parameter akun:
- Nama - teks, dari 1 hingga 12 karakter.
- Judul - teks, dari 1 hingga 30 karakter.
- Ras - daftar drop-down, lihat API untuk nilai yang valid.
- Profesi - daftar drop-down, lihat API untuk nilai yang valid.
- Level adalah angka dari 0 hingga 100.
- Ulang tahun - tanggal (<input type="date" ...).
- Dilarang adalah nilai boolean.
- Sekarang tambahkan tombol, klik di mana semua data yang dimasukkan akan dikirim ke server. Gunakan permintaan POST ke URL
/rest/players
. Setelah respons server, jangan lupa untuk mengosongkan bidang entri data dan meminta ulang daftar akun di halaman saat ini. - Sekarang Anda dapat menambahkan "keindahan" melalui gaya - semuanya terserah Anda. Saya mendapatkannya seperti ini:
Harap perhatikan bahwa nilai di kolom edit harus sesuai dengan yang ada di akun.
Berguna: Server API:
Dapatkan daftar pemain
URL | / istirahat / pemain |
metode | Opsional: Bilangan bulat nomor halaman, Ukuran halaman bilangan bulat |
Parameter Data | Tidak ada |
Tanggapan Sukses |
|
catatan |
pageNumber - parameter yang bertanggung jawab atas jumlah halaman yang ditampilkan saat menggunakan paging. Penomoran dimulai dari nol. pageSize - parameter yang bertanggung jawab atas jumlah hasil pada satu halaman saat melakukan paging
|
Hitung jumlah pemain
URL | /istirahat/pemain/hitung |
metode | MENDAPATKAN |
Parameter URL | Tidak ada |
Parameter Data | Tidak ada |
Tanggapan Sukses |
Kode : 200 oke Isi : Bilangan bulat |
catatan |
Hapus pemain
URL | /rest/players/{id} |
metode | MENGHAPUS |
Parameter URL | pengenal |
Parameter Data | Tidak ada |
Tanggapan Sukses | Kode : 200 oke |
catatan |
Jika pemutar tidak ditemukan, respons berupa kesalahan dengan kode 404. Jika nilai id tidak valid, respon akan error dengan kode 400. |
Perbarui pemain
URL | /rest/players/{id} |
metode | POS |
Parameter URL | pengenal |
Parameter Data |
|
Tanggapan Sukses |
|
catatan |
Hanya bidang yang bukan nol yang diperbarui. Jika pemain tidak ditemukan di database, responsnya berupa kesalahan dengan kode 404. Jika nilai id tidak valid, responnya adalah error dengan kode 400. |
Buat pemain
URL | / istirahat / pemain |
metode | POS |
Parameter URL | Tidak ada |
Parameter Data |
|
Tanggapan Sukses |
|
catatan |
Kami tidak dapat membuat pemain jika:
Dalam kasus semua hal di atas, responsnya berupa kesalahan dengan kode 400. |
Analisis proyek . Tonton setelah selesai!
GO TO FULL VERSION