[转] C# TextBox、DataGrideView中的数据绑定

简介:

Xavierr 原文 C#数据绑定——简单的文本框绑定DataGridView

 

一、TextBox的数据绑定

经常写用一个TextBox显示某个对象,然后编辑之后再保存的程序。以前都是在TextBox_TextChanged事件中修改对象的值,或者保存的时候再读取TextBox.Text属性保存对象的值。这样比较麻烦,而且经常容易出错。后来了解了C#的数据绑定,发现能够很好的解决这个问题。

1. 首先C#的TextBox本身就带数据绑定功能。

下面的代码就是把_myData对象的"TheValue"属性绑定到textBox1和textBox2的"Text"属性。最后一个参数不同:

1)其中DataSourceUpdateMode.OnPropertyChanged表示textBox1.Text发生变化,_myData.TheValue也变化,叫双向绑定。

2)DataSourceUpdateMode.Never表示Text1.Text变化不影响_myData.TheValue的值,是单向绑定。

1
2
3
4
5
6
private  void  Form1_Load( object  sender, EventArgs e)
{
     _myData =  new  MyData();
     textBox1.DataBindings.Add( "Text" , _myData,  "TheValue" false , DataSourceUpdateMode.OnPropertyChanged);
     textBox2.DataBindings.Add( "Text" , _myData,  "TheValue" false , DataSourceUpdateMode.Never);
}

 

2.也许有人留意到了,为什么上面的叫"双向绑定"呢?如果_myData.TheValue的值变化了,两个文本框的Text会变化吗?不错,仅在 textBox上数据绑定还不叫双向绑定,对象数据变化要通知绑定该对象的控件才行。这样就需要对象实现INotifyPropertyChanged接 口。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public  class  MyData : INotifyPropertyChanged
{
     private  string  _theValue =  string .Empty;
 
     public  string  TheValue
     {
         get  return  _theValue; }
         set
         {
             if  ( string .IsNullOrEmpty(value) && value == _theValue)
                 return ;
 
             _theValue = value;
             NotifyPropertyChanged(() => TheValue);
         }
     }
 
     public  event  PropertyChangedEventHandler PropertyChanged;
 
     public  void  NotifyPropertyChanged<T>(Expression<Func<T>> property)
     {
         if  (PropertyChanged ==  null )
             return ;
 
         var  memberExpression = property.Body  as  MemberExpression;
         if  (memberExpression ==  null )
             return ;
 
         PropertyChanged.Invoke( this new  PropertyChangedEventArgs(memberExpression.Member.Name));
     }
}

 

3.好了,数据绑定完成了,看看效果吧。textBox1.Text变化—>_myData.TheValue变化—>textBox2.Text变化。反过来textBox2.Text变化就不是这样了,因为textBox2使用的单向绑定。

 

二、DataGridView的数据绑定

没什么可说的,DataGridView可以绑定DataSet,也可以绑定DataTable。直接设置DataSource属性。

1
2
3
DataSet dataSet =  new  DataSet();
dataGridView1.DataSource = dataSet;
dataGridView1.DataSource = dataSet.Tables[0];

 设置DataGridView的Column属性就可以决定哪一列显示的数据。

1
Column1.DataPropertyName =  "ID"

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。








   本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/5814894.html ,如需转载请自行联系原作者
相关文章
|
8月前
|
JavaScript
vue element plus Checkbox 多选框
vue element plus Checkbox 多选框
334 0
element-ui表单验证使用
element-ui的表单验证主要分三部分: validate options rules 最常用的是rules. 定义rule可以有三种形式: 函数: { name(rule, value, callback, source, options) {} } 对象: { name: { typ.
6698 0
|
5月前
Vue3文本域(Textarea)
这是一个基于 Vue3 的可自定义文本域组件 (`Textarea`),具备多种实用功能,如自适应内容高度、清除图标、字数统计及禁用状态等。
206 2
Vue3文本域(Textarea)
|
5月前
Vue3多选框(Checkbox)
这是一个可高度定制的多选框组件,支持多种属性设置,如复选元素数据、是否禁用、垂直排列、当前选中值、间距、展示区域宽高及全选样式控制等。提供了在线预览和示例代码,便于快速集成与自定义。
159 1
Vue3多选框(Checkbox)
|
8月前
|
JavaScript
vue element plus Radio 单选框
vue element plus Radio 单选框
195 0
|
Windows
ItemsControl的两种数据绑定方式
原文:ItemsControl的两种数据绑定方式      最近在学习ItemsControl这个控件的时候,查看了MSDN上面的一个例子,并且自己做了一些修改,这里主要使用了两种方式来进行相应的数据绑定,一种是使用DataContext,另外一种是直接将一个类绑定到前台,其实这两种方式原理差不多都...
1110 0
|
容器
数据绑定(八)使用Binding的RelativeSource
原文:数据绑定(八)使用Binding的RelativeSource 当一个Binding有明确的数据来源时可以通过为Source或ElementName赋值的办法让Binding与之关联,有的时候由于不能确定Source的对象叫什么名字,但知道它与作为Binding目标的对象在UI布局上有相对关系,比如控件自己关联自己的某个数据、关联自己某级容器的数据,就要使用Binding的RelativeSource属性。
790 0