BackboneJS - Aplikasi

BackboneJS memberikan struktur pada aplikasi web yang memungkinkan untuk memisahkan logika bisnis dan logika antarmuka pengguna. Pada bab ini, kita akan membahas gaya arsitektur aplikasi BackboneJS untuk mengimplementasikan antarmuka pengguna. Diagram berikut menunjukkan arsitektur BackboneJS -

Arsitektur BackboneJS berisi modul-modul berikut -

  • Permintaan HTTP
  • Router
  • View
  • Events
  • Model
  • Collection
  • Sumber data

Sekarang mari kita bahas semua modul secara rinci.

Permintaan HTTP

Klien HTTP mengirimkan permintaan HTTP ke server dalam bentuk pesan permintaan di mana browser web, mesin telusur, dll., Bertindak seperti klien HTTP. Permintaan pengguna untuk file seperti dokumen, gambar, dll., Menggunakan protokol permintaan HTTP. Pada diagram di atas, Anda dapat melihat bahwa klien HTTP menggunakan router untuk mengirim permintaan klien.

Router

Ini digunakan untuk merutekan aplikasi sisi klien dan menghubungkannya ke tindakan dan acara menggunakan URL. Ini adalah representasi URL dari objek aplikasi. URL ini diubah secara manual oleh pengguna. URL digunakan oleh tulang punggung sehingga dapat memahami status aplikasi apa yang akan dikirim atau disajikan kepada pengguna.

Router adalah mekanisme yang dapat menyalin URL untuk mencapai tampilan. Router diperlukan ketika aplikasi web menyediakan URL yang dapat ditautkan, dibookmark, dan dibagikan untuk lokasi penting di aplikasi.

Dalam arsitektur di atas, router mengirimkan permintaan HTTP ke View. Ini adalah fitur yang berguna ketika aplikasi membutuhkan kemampuan perutean.

Melihat

Tampilan BackboneJS bertanggung jawab atas bagaimana dan apa yang akan ditampilkan dari aplikasi kita dan tidak mengandung markup HTML untuk aplikasi tersebut. Ini menentukan ide di balik presentasi data model kepada pengguna. Tampilan digunakan untuk mencerminkan "seperti apa model data Anda".

Kelas tampilan tidak tahu apa-apa tentang HTML dan CSS dan setiap tampilan dapat diperbarui secara independen saat model berubah tanpa memuat ulang seluruh halaman. Ini mewakili bagian logis dari UI di DOM.

Seperti yang ditunjukkan pada arsitektur di atas, View mewakili antarmuka pengguna yang bertanggung jawab untuk menampilkan respons atas permintaan pengguna yang dilakukan dengan menggunakan Router.

Acara

Acara adalah bagian utama dari aplikasi apa pun. Ini mengikat acara khusus pengguna ke aplikasi. Mereka dapat dicampur menjadi objek apa pun dan mampu mengikat dan memicu peristiwa khusus. Anda dapat mengikat acara khusus dengan menggunakan nama pilihan Anda yang diinginkan.

Biasanya, acara ditangani secara sinkron dengan alur programnya. Dalam arsitektur di atas, Anda bisa melihat ketika suatu peristiwa terjadi, itu mewakili data model dengan menggunakan View.

Model

Ini adalah jantung dari aplikasi JavaScript yang mengambil dan mengisi data. Model berisi data dari suatu aplikasi, logika dari data dan merepresentasikan objek data dasar dalam kerangka.

Model mewakili entitas bisnis dengan beberapa logika bisnis dan validasi bisnis. Mereka terutama digunakan untuk penyimpanan data dan logika bisnis. Model dapat diambil dari dan disimpan ke penyimpanan data. Model mengambil permintaan HTTP dari Peristiwa yang diteruskan oleh Tampilan menggunakan Router dan menyinkronkan data dari database dan mengirimkan respons kembali ke klien.

Koleksi

Koleksi adalah sekumpulan model yang mengikat peristiwa, ketika model telah dimodifikasi dalam koleksi. Koleksi tersebut berisi daftar model yang dapat diproses dalam perulangan dan mendukung pengurutan dan pemfilteran. Saat membuat koleksi, kita dapat menentukan jenis model apa yang akan dimiliki oleh koleksi tersebut bersama dengan instance properti. Setiap peristiwa yang dipicu pada model juga akan dipicu pada pengumpulan di model tersebut.

Ia juga mengambil permintaan dari view, mengikat event dan menyinkronkan data dengan data yang diminta dan mengirimkan respon kembali ke klien HTTP.

Sumber data

Ini adalah koneksi yang diatur ke database dari server dan berisi informasi yang diminta dari klien. Alur arsitektur BackboneJS dapat dijelaskan seperti yang ditunjukkan pada langkah-langkah berikut -

  • Seorang Pengguna meminta data menggunakan router, yang merutekan aplikasi ke peristiwa menggunakan URL.

  • Tampilan merepresentasikan data model kepada pengguna.

  • Model dan koleksi mengambil dan mengisi data dari database dengan mengikat peristiwa khusus.

Pada bab berikutnya, kita akan memahami pentingnya Events di BackboneJS.