MVC Dalam Delphi Programming
Author : Muchammad Aly mBA, S.Kom Dalam pembuatan aplikasi database dengan Delphi, umumnya kita menggunakan komponenkomponen database, baik berupa komponen koneksi (Misal: TAdoConnection, IBDatabase, dst), turunan TDataset (Misal: TAdoTable, TQuery, dst) atau kontrol databound (DBGrid, DBEdit, dst). Dengan pendekatan pengembangan aplikasi seperti ini, kita biasa menuliskan perintah sql, business logic, validasi input, pengaturan tampilan sekaligus dalam satu form (satu unit). Pengembangan aplikasi ini mempunyai kelemahan dari satu sisi. Diantaranya: 1. Sulit dikembangkan dalam suatu tim yang saling bekerja sama. Misalkan tim yang menangani desain tampilan, ketika menyisipkan/ mengedit kode-kode yang merubah tampilan sangat boleh jadi business logic menjadi ikut terpengaruh. Demikian juga ketika tim yang menangani database, ketika dibutuhkan perubahan perintah sql, sangat boleh jadi tingkah laku form akan berubah. 2. Sulit dimaintenance. Programmer yang meneruskan pengembangan aplikasi mau tidak mau harus memahami source code secara keseluruhan sebelum dapat ikut berpartisipasi. Hal ini disebabkan keterkaitan yang demikian erat logika pemrograman dalam satu form/satu unit. Satu perubahan yang kecil dapat mempengaruhi keseluruhan tingkah laku form. Untuk menghindari hal tersebut di atas dibutuhkan pemisahan penulisan source code dalam bagian-bagian tertentu. Salah satu metode pemisahan source code ini adalah dengan menggunakan paradigma MVC yang merupakan kependekan dari Model View Controller.
Pengertian MVC
Yaitu suatu istilah metode pengembangan / pembuatan aplikasi dengan memisahkan elemenelemen penulisan source code menjadi tiga bagian, yaitu:
Model
Model di sini berperan sebagai representasi dari data yang terlibat dalam suatu proses transaksi. Setiap kali method / function dari suatu aplikasi butuh untuk melakukan akses ke dalam suatu data, maka function / method tersebut tidak langsung berinteaksi dengan sumber data tersebut melainkan harus melalui model terlebih dahulu. Secara praktis, dalam pemrograman database Delphi, model ini berwujud unit-unit yang berisi perintah SQL dan koneksi database.
View
View di sini berperan sebagai presentation layer atau pengatur user interface (tampilan) bagi user dari suatu aplikasi. Data yang dibutuhkan oleh user akan diformat sedemikian rupa agar dapat tampil dan dipresentasikan dengan format tampilan yang memang disesuaikan dengan kebutuhkan user, biasanya layer View juga bertugas untuk melakukan validasi data
yang diinputkan user. Secara praktis, dalam pemrograman Delphi, view berwujud unit form yang hanya berisi perintah-perintah yang berhubungan dengan efek tampilan dan bagaimana data itu ditampilkan.
Controller
Controller di sini berperan sebagai logic aspect dari suatu aplikasi / mengatur user flow. Controller lah yang akan menentukan bussiness process dari aplikasi yang dibangun. Controller akan merespon setiap inputan dari user dengan melakukan pemanggilan terhadap model dan view yang sesuai sehingga request / permintaan dari user tersebugt dapat terpenuhi dengan baik. Biasanya layer controller juga digunakan untuk mengatur ijin akses dan permission. Secara praktis, dalam pemrograman Delphi, controller dapat berupa unit yang berisi function / procedure yang berisi logika bisnis.
MVC dan MVP
MVP (Model View Presentation) adalah turunan dari MVC. Presentation mempunyai kesamaan fungsi dengan Controller. Perbedaan MVC dan MVP hanya terletak pada arah komunikasi antar elemen. Pada MVC, View bisa langsung berkomunikasi dengan Model tanpa melalui Controller. Pada MVP, komunikasi View dengan Model harus melalui Presentation. Berikut ini ilustrasi yang menggambarkan perbedaan MVC dan MPV
Contoh PENERAPAN MVC dan MVP DALAM DELPHI PROGRAMMING
Pada contoh di atas, komunikasi antara View dan Model pada MVC terjadi melalui penggunaan variabel SearchResult pada unit first_model.pas.
Pada contoh MVP di atas, komunikasi antara View ke Model terjadi melaui Presentation dengan kembalian nilai dari Presentation.