關於.NET中WinForms裡面的ListBox實現資料繫結的解決方法 (轉)
在中,WINDOW FORMS下面的LIST BOX在開發時,如果採用其本身的資料繫結,繫結完以後就不能更改ListBox的Items了.而實際開發中卻經常會碰到要改變的情況,在這裡我提供了一重方法.採用開發繼承ListBox控制元件的自定義控制元件.然後在裡面提供兩個SortedList類的屬性,一個可以存放ID,一個存放TEXT,這樣就解決了上面說的問題!!
控制元件的程式碼如下:
using System;
using System.Collections;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System..Forms;
namespace FlowManage
{
///
/// SysListBox 的摘要說明。
///
public class SysListBox : System.Windows.Forms.ListBox
{
private SortedList _sl=new SortedList();
///
/// 必需的設計器變數。
///
private System.ComponentModel.Container components = null;
public SysListBox()
{
// 該是 Windows.Forms 窗體設計器所必需的。
InitializeComponent();
// TODO: 在 InitializeComponent 呼叫後新增任何初始化
}
///
/// 清理所有正在使用的資源。
///
protected overr void Dispose( bool disposing )
{
if( disposing )
{
if(components != null)
{
components.Dispose();
}
}
base.Dispose( disposing );
}
public SortedList DataValues
{
get
{
return _sl;
}
set
{
_sl=value;
}
}
public void AddItem( key,object text)
{
if(this.DataValues==null)
{
this.DataValues=new SortedList();
}
this.DataValues.Add(key,text);
}
public void RemoveItem(int index)
{
this.DataValues.RemoveAt(index);
}
public void RemoveItem()
{
this.DataValues.Clear();
}
public void BoundList()
{
this.Items.Clear();
if(this.DataValues!=null)
{
this.BeginUpdate();
for(int i=0;i
this.Items.Add(this.DataValues.GetByIndex(i).ToString());
}
this.EndUpdate();
}
}
#region Component Designer generated code
///
/// 設計器支援所需的方法 - 不要使用程式碼編輯器
/// 修改此方法的內容。
///
private void InitializeComponent()
{
components = new System.ComponentModel.Container();
}
#endregion
}
}
而在呼叫這個控制元件時的程式碼如下:
string mkey=this.listCanSel.DataValues.GetKey(this.listCanSel.edIndex).ToString();
string mtext=this.listCanSel.DataValues.GetByIndex(this.listCanSel.SelectedIndex).ToString();
this.listSel.AddItem(mkey,mtext);
this.listCanSel.RemoveItem(this.listCanSel.SelectedIndex);
this.listSel.Items.Add(mtext);
this.listCanSel.Items.RemoveAt(this.listCanSel.SelectedIndex);
以上只是個人使用中的拙見,歡迎大家提出更好的解決辦法!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10748419/viewspace-959320/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- asp.net 2個ListBox之間轉移資料的實現ASP.NET
- Kubenetes裡pod和service繫結的實現方式
- 如何實現VM框架中的資料繫結框架
- 基於vue實現的雙向資料繫結Vue
- 關於JavaScript中this的軟繫結JavaScript
- MVVM模式和在WPF中的實現(二)資料繫結MVVM模式
- javascript實現資料的雙向繫結(手動繫結)JavaScript
- Java中關於OOM的場景及解決方法(轉)JavaOOM
- 【阿不】深入ASP.NET資料繫結(中)—資料雙向繫結機理ASP.NET
- 關於利用jQuery實現愛奇藝裡面的滑鼠移入改變當前頁面的功能的實現原理jQuery
- 在winform中如何實現雙向資料繫結?ORM
- Java關於資料結構的實現:樹Java資料結構
- 關於DSS中的繫結變數變數
- Vue 中實現雙向繫結的 4 種方法Vue
- 雙向資料繫結實現原理
- javascript實現雙向資料繫結JavaScript
- Java關於資料結構的實現:雜湊Java資料結構
- 關於pl/sql中的繫結變數SQL變數
- js 實現vue的雙向資料繫結JSVue
- vue資料雙向繫結的實現原理Vue
- Vue原始碼探究-資料繫結的實現Vue原始碼
- Angular Ngrx Store 裡 State 和 Reducer 的繫結關係是如何實現的Angular
- 關於java中實現在oracle資料庫中實現對中文首字母進行排序的解決方案JavaOracle資料庫排序
- 關於資料庫中的型別和entity bean裡面的型別對應問題資料庫型別Bean
- 關於laravel 框架實現路由自動注入解決方法Laravel框架路由
- Android下實現資料繫結功能Android
- Android Studio中Spinner控制元件的資料繫結實現Android控制元件
- VB.NET中怎樣為listview繫結資料View
- angularjs中的資料繫結AngularJS
- JavaScript實現簡單的雙向資料繫結JavaScript
- 關於sql_profile中的繫結變數SQL變數
- Wicket中JQuery事件繫結失效的解決jQuery事件
- Study Blazor .NET(四)資料繫結Blazor
- .NET基礎之資料繫結
- 常用的前臺資料繫結方法
- 如何在原生微信小程式中實現資料雙向繫結微信小程式
- 淺談Vue中的資料繫結的實現,以及Vue3.0的proxyVue
- 實現更好DEVOPS,關鍵取決於資料dev