Bagikan melalui


Gambaran umum pengikatan data dengan Windows Forms

Di Windows Forms, Anda dapat mengikat ke tidak hanya sumber data tradisional, tetapi juga ke hampir semua struktur yang berisi data. Anda dapat mengikat ke array nilai yang Anda hitung pada waktu proses, membaca dari file, atau berasal dari nilai kontrol lain.

Selain itu, Anda dapat mengikat properti apa pun dari kontrol apa pun ke sumber data. Dalam pengikatan data tradisional, Anda biasanya mengikat properti tampilan—misalnya, Text properti TextBox kontrol—ke sumber data. Dengan .NET, Anda juga memiliki opsi untuk mengatur properti lain melalui pengikatan. Anda mungkin menggunakan pengikatan untuk melakukan tugas berikut:

  • Mengatur grafik kontrol gambar.

  • Mengatur warna latar belakang dari satu atau beberapa kontrol.

  • Mengatur ukuran kontrol.

Pada dasarnya, pengikatan data adalah cara otomatis untuk mengatur properti yang dapat diakses saat run-time dari kontrol apa pun dalam formulir.

ADO.NET memungkinkan Anda membuat banyak struktur data yang berbeda agar sesuai dengan kebutuhan pengikatan aplikasi Anda dan data yang sedang Anda kerjakan. Anda mungkin ingin membuat kelas Anda sendiri yang menyediakan atau menggunakan data di Formulir Windows. Objek ini dapat menawarkan berbagai tingkat fungsionalitas dan kompleksitas. Mulai dari pengikatan data dasar, hingga menyediakan dukungan pada saat perancangan, pemeriksaan kesalahan, pemberitahuan perubahan, atau bahkan dukungan untuk pengembalian terstruktur perubahan yang dilakukan pada data itu sendiri.

Pengguna antarmuka pengikatan data

Bagian berikut menjelaskan dua grup objek antarmuka. Grup antarmuka pertama diimplementasikan pada sumber data oleh penulis sumber data. Konsumen sumber data seperti kontrol atau komponen Windows Forms mengimplementasikan antarmuka ini. Grup antarmuka kedua dirancang untuk digunakan oleh penulis komponen. Penulis komponen menggunakan antarmuka ini saat mereka membuat komponen yang mendukung pengikatan data untuk dikonsumsi oleh mesin pengikatan data Formulir Windows. Anda dapat menerapkan antarmuka ini dalam kelas yang terkait dengan formulir Anda untuk mengaktifkan pengikatan data. Setiap kasus menyajikan kelas yang mengimplementasikan antarmuka yang memungkinkan interaksi dengan data. Alat pengalaman desain data pengembangan aplikasi cepat Visual Studio (RAD) sudah memanfaatkan fungsionalitas ini.

Antarmuka untuk implementasi oleh penulis sumber data

Kontrol Windows Forms mengimplementasikan antarmuka berikut:

  • antarmuka IList

    Kelas yang mengimplementasikan IList antarmuka bisa berupa Array, , ArrayListatau CollectionBase. Ini adalah daftar item terindeks jenis Object dan daftar harus berisi jenis homogen, karena item pertama indeks menentukan jenisnya. IList akan tersedia untuk pengikatan hanya pada waktu proses.

    Nota

    Jika Anda ingin membuat daftar objek bisnis untuk pengikatan dengan Windows Forms, Anda harus mempertimbangkan untuk menggunakan BindingList<T>. BindingList adalah kelas yang dapat diperluas yang mengimplementasikan antarmuka utama yang diperlukan untuk pengikatan data Windows Forms dua arah.

  • antarmuka IBindingList

    Kelas yang mengimplementasikan IBindingList antarmuka menyediakan tingkat fungsionalitas pengikatan data yang jauh lebih tinggi. Implementasi ini menawarkan kemampuan pengurutan dasar dan pemberitahuan perubahan. Keduanya berguna ketika item daftar berubah, dan ketika daftar itu sendiri berubah. Pemberitahuan perubahan penting jika Anda berencana untuk memiliki beberapa kontrol yang terikat ke data yang sama. Ini membantu Anda membuat perubahan data yang dibuat di salah satu kontrol untuk disebarluaskan ke kontrol terikat lainnya.

    Nota

    Pemberitahuan perubahan diaktifkan untuk antarmuka IBindingList melalui properti SupportsChangeNotification yang, ketika true, memicu peristiwa ListChanged, menunjukkan perubahan daftar atau item dalam daftar berubah.

    Jenis perubahan dijelaskan oleh ListChangedType properti ListChangedEventArgs parameter . Oleh karena itu, setiap kali model data diperbarui, tampilan dependen apa pun, seperti kontrol lain yang terikat ke sumber data yang sama, juga akan diperbarui. Namun, objek yang terkandung dalam daftar harus memberi tahu daftar saat berubah sehingga daftar dapat mengaktifkan ListChanged event.

    Nota

    BindingList<T> menyediakan implementasi generik antarmukaIBindingList.

  • antarmuka IBindingListView

    Kelas yang mengimplementasikan IBindingListView antarmuka menyediakan semua fungsionalitas implementasi IBindingList, bersama dengan fungsionalitas pemfilteran dan pengurutan tingkat lanjut. Implementasi ini menawarkan pemfilteran berbasis string, dan pengurutan multi-kolom dengan pasangan arah deskriptor properti.

  • antarmuka IEditableObject

    Kelas yang mengimplementasikan IEditableObject antarmuka memungkinkan objek untuk mengontrol kapan perubahan pada objek tersebut dibuat permanen. Implementasi ini mendukung BeginEditmetode , EndEdit, dan CancelEdit , yang memungkinkan Anda untuk mengembalikan perubahan yang dilakukan pada objek. Berikut ini adalah penjelasan singkat tentang fungsi metode BeginEdit, EndEdit, dan CancelEdit serta bagaimana mereka bekerja satu sama lain untuk memungkinkan pemulihan perubahan yang dilakukan pada data:

    • Metode ini BeginEdit menandakan dimulainya pengeditan pada objek. Objek yang mengimplementasikan antarmuka ini perlu menyimpan pembaruan apa pun setelah panggilan metode BeginEdit dengan cara sehingga pembaruan dapat dibuang jika metode CancelEdit dipanggil. Dalam data yang mengikat Windows Forms, Anda dapat memanggil BeginEdit beberapa kali dalam cakupan satu transaksi edit (misalnya, BeginEdit, BeginEdit, EndEdit). Implementasi IEditableObject harus melacak apakah BeginEdit sudah dipanggil dan mengabaikan panggilan berikutnya ke BeginEdit. Karena metode ini dapat dipanggil beberapa kali, penting bahwa panggilan berikutnya ke metode ini tidak merusak. Panggilan berikutnya BeginEdit tidak dapat menghancurkan pembaruan yang telah dilakukan atau mengubah data yang disimpan pada panggilan pertama BeginEdit .

    • Metode EndEdit menerapkan setiap perubahan yang terjadi sejak BeginEdit dipanggil ke objek yang mendasar, jika objek tersebut saat ini dalam mode edit.

    • Metode CancelEdit membuang perubahan apa pun yang dilakukan pada objek.

    Untuk informasi selengkapnya tentang cara BeginEditkerja metode , EndEdit, dan CancelEdit , lihat Menyimpan data kembali ke database.

    Gagasan tentang fungsionalitas data yang transaksional ini digunakan oleh pengendali DataGridView.

  • antarmuka ICancelAddNew

    Kelas yang mengimplementasikan ICancelAddNew antarmuka biasanya mengimplementasikan IBindingList antarmuka dan memungkinkan Anda untuk mengembalikan penambahan yang dibuat ke sumber data dengan AddNew metode . Jika sumber data mengimplementasikan antarmuka IBindingList, Anda juga harus mengimplementasikan antarmuka ICancelAddNew.

  • antarmuka IDataErrorInfo

    Kelas yang mengimplementasikan IDataErrorInfo antarmuka memungkinkan objek untuk menawarkan informasi kesalahan kustom ke kontrol terikat:

    • Properti Error mengembalikan teks pesan kesalahan umum (misalnya, "Terjadi kesalahan").

    • Properti Item[] mengembalikan string dengan pesan kesalahan tertentu dari kolom (misalnya, "Nilai dalam State kolom tidak valid").

  • antarmuka IEnumerable

    Kelas yang mengimplementasikan antarmuka IEnumerable biasanya digunakan oleh ASP.NET. Dukungan Windows Forms untuk antarmuka ini hanya tersedia melalui BindingSource komponen.

    Nota

    Komponen BindingSource menyalin semua IEnumerable item ke dalam daftar terpisah untuk tujuan pengikatan.

  • antarmuka ITypedList

    Kelas koleksi yang mengimplementasikan ITypedList antarmuka menyediakan fitur untuk mengontrol urutan dan kumpulan properti yang terekspos ke kontrol terikat.

    Nota

    Ketika Anda menerapkan metode GetItemProperties, dan array PropertyDescriptor tidak bernilai null, entri terakhir dalam array tersebut akan menjadi deskriptor properti yang menggambarkan properti daftar, yaitu daftar dari item-item lain.

  • antarmuka ICustomTypeDescriptor

    Kelas yang mengimplementasikan ICustomTypeDescriptor antarmuka menyediakan informasi dinamis tentang dirinya sendiri. Antarmuka ini mirip ITypedList dengan tetapi digunakan untuk objek daripada daftar. Antarmuka ini digunakan oleh DataRowView untuk menampilkan skema baris yang dasar. Implementasi ICustomTypeDescriptor sederhana disediakan oleh CustomTypeDescriptor kelas .

    Nota

    Untuk mendukung pengikatan waktu desain ke tipe yang mengimplementasikan ICustomTypeDescriptor, tipe tersebut juga harus mengimplementasikan IComponent dan ada sebagai instans pada Form.

  • antarmuka IListSource

    Kelas yang mengimplementasikan IListSource antarmuka memungkinkan pengikatan berbasis daftar pada objek non-daftar. Metode GetList dari IListSource digunakan untuk mengembalikan daftar yang dapat diikat dari objek yang tidak mewarisi dari IList. IListSource digunakan oleh kelas DataSet.

  • antarmuka IRaiseItemChangedEvents

    Kelas yang mengimplementasikan IRaiseItemChangedEvents antarmuka adalah daftar yang dapat diikat yang juga mengimplementasikan IBindingList antarmuka. Antarmuka ini digunakan untuk menunjukkan apakah jenis Anda memicu peristiwa dari tipe ListChanged melalui properti ItemChanged.

    Nota

    Anda harus menerapkan IRaiseItemChangedEvents jika sumber data Anda menyediakan properti untuk mencantumkan konversi peristiwa yang dijelaskan sebelumnya dan berinteraksi dengan BindingSource komponen. Sebaliknya, BindingSource juga akan melakukan konversi peristiwa ke dalam daftar properti yang mengakibatkan penurunan performa.

  • antarmuka ISupportInitialize

    Komponen yang mengimplementasikan antarmuka ISupportInitialize memanfaatkan pengoptimalan batch untuk mengatur properti dan menginisialisasi properti yang saling bergantung. ISupportInitialize berisi dua metode:

    • BeginInit memberi sinyal bahwa inisialisasi objek dimulai.

    • EndInit memberi sinyal bahwa inisialisasi objek selesai.

  • antarmuka ISupportInitializeNotification

    Komponen yang mengimplementasikan ISupportInitializeNotification antarmuka juga mengimplementasikan ISupportInitialize antarmuka. Antarmuka ini memungkinkan Anda untuk memberi tahu komponen lain ISupportInitialize bahwa inisialisasi selesai. Antarmuka ISupportInitializeNotification berisi dua anggota:

  • antarmuka INotifyPropertyChanged

    Kelas yang mengimplementasikan antarmuka ini adalah jenis yang menaikkan peristiwa ketika salah satu nilai propertinya berubah. Antarmuka ini dirancang untuk menggantikan pola memiliki peristiwa perubahan untuk setiap properti kontrol. Ketika digunakan dalam BindingList<T>, objek bisnis harus mengimplementasikan antarmuka INotifyPropertyChanged, dan BindingList`1 akan mengonversi peristiwa PropertyChanged menjadi peristiwa ListChanged dengan jenis ItemChanged.

    Nota

    Agar pemberitahuan perubahan terjadi dalam pengikatan antara klien terikat dan sumber data, jenis sumber data terikat Anda harus mengimplementasikan INotifyPropertyChanged antarmuka (pilihan) atau Anda dapat menyediakan peristiwa propertyNameChanged untuk jenis terikat, tetapi Anda tidak boleh melakukan keduanya.

Antarmuka untuk implementasi oleh penulis komponen

Antarmuka berikut dirancang untuk dikonsumsi oleh mesin pengikatan data Windows Forms:

Sumber data yang didukung oleh Windows Forms

Secara tradisional, pengikatan data telah digunakan dalam aplikasi untuk memanfaatkan data yang disimpan dalam database. Dengan pengikatan data Windows Forms, Anda dapat mengakses data dari database dan data di struktur lain, seperti array dan koleksi, selama persyaratan minimum tertentu telah terpenuhi.

Struktur untuk mengikat Ke

Di Windows Forms, Anda dapat mengikat ke berbagai struktur, dari objek sederhana (pengikatan sederhana) ke daftar kompleks seperti tabel data ADO.NET (pengikatan kompleks). Untuk pengikatan sederhana, Windows Forms mendukung pengikatan ke properti publik pada objek sederhana. Pengikatan berbasis daftar Windows Forms umumnya mengharuskan objek mendukung IList antarmuka atau IListSource antarmuka. Selain itu, jika Anda mengikat melalui BindingSource komponen, Anda dapat mengikat ke objek yang mendukung IEnumerable antarmuka.

Daftar berikut ini memperlihatkan struktur yang bisa Anda ikat di Formulir Windows.

  • BindingSource

    BindingSource adalah sumber data Windows Forms yang paling umum dan bertindak proksi antara sumber data dan kontrol Windows Forms. Pola penggunaan BindingSource umum adalah mengikat kontrol Anda ke BindingSource dan mengikat BindingSource ke sumber data (misalnya, tabel data ADO.NET atau objek bisnis). BindingSource menyediakan layanan yang memungkinkan dan meningkatkan tingkat dukungan pengikatan data. Misalnya, kontrol berbasis daftar Formulir Windows seperti DataGridView dan ComboBox tidak secara langsung mendukung pengikatan ke IEnumerable sumber data namun, Anda dapat mengaktifkan skenario ini dengan mengikat melalui BindingSource. Dalam hal ini, BindingSource akan mengonversi sumber data menjadi IList.

  • Objek sederhana

    Windows Forms mendukung pengikatan data pada properti kontrol ke properti publik pada instans objek menggunakan tipe Binding. Windows Forms juga mendukung pengikatan kontrol berbasis daftar, seperti ListControl ke instans objek saat BindingSource digunakan.

  • Array atau Koleksi

    Untuk bertindak sebagai sumber data, daftar harus mengimplementasikan antarmuka IList; salah satu contohnya adalah array yang merupakan instans kelas Array. Untuk informasi selengkapnya tentang array, lihat Cara: Membuat Array Objek (Visual Basic).

    Secara umum, Anda harus menggunakan BindingList<T> saat membuat daftar objek untuk pengikatan data. BindingList adalah versi generik dari antarmuka IBindingList. Antarmuka IBindingList memperluas antarmuka IList dengan menambahkan properti, metode, dan peristiwa yang diperlukan untuk pengikatan data dua arah.

  • IEnumerable

    Kontrol Windows Forms dapat diikat ke sumber data yang hanya mendukung antarmuka IEnumerable jika melalui komponen BindingSource.

  • ADO.NET objek data

    ADO.NET menyediakan banyak struktur data yang cocok untuk diikat. Masing-masing bervariasi dalam kecanggih dan kompleksitasnya.

    • DataColumn

      DataColumn adalah blok penyusun penting dari DataTable, karena beberapa kolom membentuk sebuah tabel. Setiap DataColumn memiliki properti DataType yang menentukan jenis data yang dimiliki kolom (misalnya, merek mobil dalam tabel yang menyajikan informasi tentang mobil). Anda dapat mengikat secara sederhana sebuah kontrol (seperti kontrol TextBox pada properti Text) ke kolom dalam tabel data.

    • DataTable

      DataTable adalah representasi tabel, dengan baris dan kolom, dalam ADO.NET. Tabel data berisi dua koleksi: DataColumn, mewakili kolom data dalam tabel tertentu (yang pada akhirnya menentukan jenis data yang dapat dimasukkan ke dalam tabel tersebut), dan DataRow, mewakili baris data dalam tabel tertentu. Anda dapat mengikat kontrol ke informasi yang terkandung dalam tabel data (seperti mengikat kontrol DataGridView ke tabel data). Namun, saat Anda mengikat ke DataTable, Anda terikat ke tampilan default tabel.

    • DataView

      DataView adalah tampilan yang dikustomisasi dari satu tabel data yang mungkin difilter atau diurutkan. Tampilan data adalah "rekam jepret" data yang digunakan oleh kontrol yang terikat kompleks. Anda dapat melakukan pengikatan sederhana atau pengikatan kompleks ke data dalam tampilan data, tetapi perhatikan bahwa Anda mengikat ke cuplikan data tetap daripada ke sumber data dinamis yang terus diperbarui.

    • DataSet

      DataSet adalah kumpulan tabel, hubungan, dan batasan data dalam database. Anda dapat mengikat sederhana atau mengikat kompleks ke data dalam himpunan data, tetapi perhatikan bahwa Anda mengikat ke default DataViewManager untuk DataSet (lihat poin berikutnya).

    • DataViewManager

      DataViewManager adalah tampilan yang disesuaikan dari seluruh DataSet, mirip dengan DataView, namun mencakup hubungan. Dengan koleksi DataViewSettings, Anda dapat mengatur filter default dan opsi pengurutan untuk tampilan apa pun yang DataViewManager miliki untuk tabel tertentu.

Jenis pengikatan data

Windows Forms dapat memanfaatkan dua jenis pengikatan data: pengikatan sederhana dan pengikatan kompleks. Masing-masing menawarkan keuntungan yang berbeda.

Jenis pengikatan data Deskripsi
Pengikatan data sederhana Kemampuan kontrol untuk mengikat ke elemen data tunggal, seperti nilai dalam kolom dalam tabel himpunan data. Pengikatan data sederhana adalah jenis pengikatan yang khas untuk kontrol seperti TextBox kontrol atau Label kontrol, yang merupakan kontrol yang biasanya hanya menampilkan satu nilai. Bahkan, properti apa pun pada kontrol dapat terikat ke bidang dalam database. Ada dukungan ekstensif untuk fitur ini di Visual Studio.

Untuk informasi selengkapnya, lihat Menavigasi data dan Membuat kontrol terikat sederhana (Windows Forms .NET).
Pengikatan data kompleks Kemampuan kontrol untuk mengikat ke lebih dari satu elemen data, biasanya lebih dari satu rekaman dalam database. Pengikatan kompleks juga disebut pengikatan berbasis daftar. Contoh kontrol yang mendukung pengikatan kompleks adalah DataGridViewkontrol , , ListBoxdan ComboBox . Untuk contoh pengikatan data kompleks, lihat Cara: Mengikat Windows Forms ComboBox atau Kontrol ListBox ke Data.

Komponen sumber pengikatan

Untuk menyederhanakan pengikatan data, Windows Forms memungkinkan Anda untuk mengikat sumber data ke BindingSource komponen lalu mengikat kontrol ke BindingSource. Anda dapat menggunakan BindingSource dalam skenario pengikatan sederhana atau kompleks. Dalam kedua kasus, BindingSource bertindak sebagai perantara antara sumber data dan kontrol terikat yang menyediakan manajemen mata uang pemberitahuan perubahan dan layanan lainnya.

Skenario umum yang menggunakan pengikatan data

Hampir setiap aplikasi komersial menggunakan informasi yang dibaca dari sumber data dari satu jenis atau jenis lainnya, biasanya melalui pengikatan data. Daftar berikut menunjukkan beberapa skenario paling umum yang menggunakan pengikatan data sebagai metode presentasi dan manipulasi data.

Skenario Deskripsi
Pelaporan Laporan menyediakan cara yang fleksibel bagi Anda untuk menampilkan dan meringkas data Anda dalam dokumen cetak. Biasanya membuat laporan yang mencetak konten sumber data yang dipilih baik ke layar atau ke printer. Laporan umum mencakup daftar, faktur, dan ringkasan. Item diformat ke dalam kolom daftar, dengan subitem yang diatur di bawah setiap item daftar, tetapi Anda harus memilih tata letak yang paling sesuai dengan data.
Entri data Cara umum untuk memasukkan sejumlah besar data terkait atau untuk meminta informasi kepada pengguna adalah melalui formulir entri data. Pengguna dapat memasukkan informasi atau memilih pilihan menggunakan kotak teks, tombol opsi, daftar drop-down, dan kotak centang. Informasi kemudian dikirimkan dan disimpan dalam database, yang strukturnya didasarkan pada informasi yang dimasukkan.
Hubungan master/detail Aplikasi master/detail adalah salah satu format untuk melihat data terkait. Secara khusus, ada dua tabel data dengan hubungan yang terhubung dalam contoh bisnis klasik, tabel "Pelanggan" dan tabel "Pesanan" dengan hubungan antara mereka yang menautkan pelanggan dan pesanan masing-masing. Untuk informasi selengkapnya tentang membuat aplikasi master/detail dengan dua kontrol Windows Forms DataGridView, lihat Cara: Membuat Form Master/Detail Menggunakan Dua Kontrol DataGridView Windows Forms.
Tabel Pencarian Skenario presentasi/manipulasi data umum lainnya adalah pencarian tabel. Seringkali, kontrol digunakan sebagai bagian dari tampilan data yang lebih besar untuk menampilkan dan memanipulasi data. Kuncinya adalah bahwa data yang ditampilkan dalam ComboBox kontrol berbeda dari data yang ditulis ke database. Misalnya, jika Anda memiliki ComboBox kontrol yang menampilkan barang-barang yang tersedia dari toko kelontong, Anda mungkin ingin melihat nama-nama produk (roti, susu, telur). Namun, untuk memudahkan pengambilan informasi dalam database dan untuk normalisasi database, Anda mungkin akan menyimpan informasi untuk item tertentu dari pesanan tertentu sebagai nomor item (#501, #603, dan sebagainya). Dengan demikian, ada koneksi implisit antara "nama yang mudah diingat" barang belanja dalam kontrol formulir Anda dan nomor barang terkait yang terdapat dalam pesanan. Ini adalah esensi dari pencarian tabel. Untuk informasi selengkapnya, lihat Cara: Membuat Tabel Pencarian dengan Komponen Windows Forms BindingSource.

Lihat juga