TextBox控件的DataBindings属性

DataBindings属性是很多控件都有的属性,作用有2方面。一方面是用于与数据库的数据进行绑定,进行数据显示。另一方面用于与控件或类的对象进行数据绑定。这里主要关注后者。主要用法是将某个对象的某个属性与指定对象的指定属性进行关联.

Label、TextBox等都包含DataBindings属性,其类型为ControlBindingsCollection,是Binding类的集合。Binding类代表某对象属性值和某控件属性值之间的简单绑定。如可以将TextBox的Text属性值绑定到Label的Text属性值,这样,当TextBox中的文本被修改的时候,Label的文本也会及时进行修改,如下面的代码所示:

Label1.DataBindings.Add("Text",TextBox1,"Text");

Binding类除了可以将对象的属性绑定到控件的属性之外,还可以将对象列表中当前对象的属性值绑定到控件的属性。

当使用Binding的构造函数创建实例时,必须指定三项内容:

  • 要绑定到的控件属性的名称
  • 数据源
  • 数据源中解析为列表或属性的导航路径

其中,数据源可以为:

  • 实现 IBindingList 或 ITypedList 的任何类。包括:DataSet、DataTable、DataView 或 DataViewManager。
  • 实现 IList 的任意索引集合类。(必须在创建 Binding 之前创建和填充该集合,并且列表中的所有对象必须为同一类型,否则将引发异常)
  • 强类型对象的强类型 IList。

导航路径可以为空字符串(默认将调用数据源的ToString()方法)、单个属性名称或用点分隔的名称层次结构。

名称层次结构是什么意思呢?比如我们有一个Company类,它包含Name属性和Employees属性(公司所有Employee的集合),而Employee类又包含Name属性。那么,如果要将Company的Name属性绑定到TextBox控件的Text属性,代码为:

TextBox1.DataBindings.Add("Text", company, "Name");

.csharpcode,.csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff }
.csharpcode pre { margin: 0em }
.csharpcode .rem { color: #008000 }
.csharpcode .kwrd { color: #0000ff }
.csharpcode .str { color: #006080 }
.csharpcode .op { color: #0000c0 }
.csharpcode .preproc { color: #cc6633 }
.csharpcode .asp { background-color: #ffff00 }
.csharpcode .html { color: #800000 }
.csharpcode .attr { color: #ff0000 }
.csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em }
.csharpcode .lnum { color: #606060 }

如果要绑定Employees的Name属性,代码为:

TextBox1.DataBindings.Add("Text", company, "Employees.Name");

.csharpcode,.csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff }
.csharpcode pre { margin: 0em }
.csharpcode .rem { color: #008000 }
.csharpcode .kwrd { color: #0000ff }
.csharpcode .str { color: #006080 }
.csharpcode .op { color: #0000c0 }
.csharpcode .preproc { color: #cc6633 }
.csharpcode .asp { background-color: #ffff00 }
.csharpcode .html { color: #800000 }
.csharpcode .attr { color: #ff0000 }
.csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em }
.csharpcode .lnum { color: #606060 }

Employess.Name即为用点分隔的名称层次结构。在这里,Employees为一个集合,将Employees.Name绑定到TextBox会出现什么情况呢?测试后可知,TextBox将显示Employees集合中第一个Employee的Name属性。

示例:

界面

代码实现:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.ComponentModel;
 4 using System.Data;
 5 using System.Drawing;
 6 using System.Linq;
 7 using System.Text;
 8 using System.Threading.Tasks;
 9 using System.Windows.Forms;
10
11 namespace DataBindingsDemo
12 {
13     public partial class FrmDataBindings : Form
14     {
15         public FrmDataBindings()
16         {
17             InitializeComponent();
18         }
19
20         private void FrmDataBindings_Load(object sender, EventArgs e)
21         {
22             //绑定到DataTable
23             DataTable dtSource = GetDataTable();
24             this.textBox1.DataBindings.Add("Text", dtSource, "StudentNo");
25             this.textBox2.DataBindings.Add("Text", dtSource, "StudentName");
26             this.textBox3.DataBindings.Add("Text", dtSource, "Sex");
27
28             //绑定到实体对象
29             Student stu = new Student() { StudentNo=2,StudentName="测试2",Sex="女"};
30             //必须是绑定到对象的属性(此例中绑定到StudentNo,而不是student),
31             this.textBox4.DataBindings.Add("Text", stu, "StudentNo");
32             this.textBox5.DataBindings.Add("Text", stu, "StudentName");
33             this.textBox6.DataBindings.Add("Text", stu, "Sex");
34         }
35
36         private DataTable GetDataTable()
37         {
38             DataTable dt = new DataTable();
39             DataColumn dcNo = new DataColumn("StudentNo", typeof(Int32));
40             DataColumn dcName = new DataColumn("StudentName", typeof(string));
41             DataColumn dcSex = new DataColumn("Sex", typeof(string));
42             dt.Columns.Add(dcNo);
43             dt.Columns.Add(dcName);
44             dt.Columns.Add(dcSex);
45             dt.Rows.Add(new object[] { 1,"测试","男"});
46             return dt;
47         }
48     }
49
50     public class Student
51     {
52         private int studentNo;
53
54         public int StudentNo
55         {
56             get { return studentNo; }
57             set { studentNo = value; }
58         }
59
60         private string studentName;
61
62         public string StudentName
63         {
64             get { return studentName; }
65             set { studentName = value; }
66         }
67
68         private string sex;
69
70         public string Sex
71         {
72             get { return sex; }
73             set { sex = value; }
74         }
75     }
76 }

运行效果:

时间: 2024-10-09 09:54:25

TextBox控件的DataBindings属性的相关文章

windows phone开发中textbox控件的header属性

备注:博主windows phone学习新手,在博客园上分享自己刚刚掌握的一些学习笔记,内容简单,高手勿喷! 前一段时间看@消失3003的博客,发现了textboxt的header属性.这一属性在编写UI时可以节约不少代码,十分有用. 之前编写一个如下的微信登陆界面,代码会很长: 未使用Header属性的UI及代码: 代码如下: <Grid> <TextBlock Text="登录" FontSize="20" Margin="0,15,

[摘]ASP.Net标准控件(TextBox控件)

TextBox控件 TextBox控件又称文本框控件,为用户提供输入文本的功能. 1.属性 TextBox控件的常用属性及说明如表1所示. 表1 TextBox控件常用属性及说明 属    性 说    明 AutoPostBack 获取或设置一个值,该值指示无论何时用户在TextBox控件中按〈Enter〉键或〈Tab〉键时,是否自动回发到服务器的操作 CausesValidation 获取或设置一个值,该值指示当TextBox控件设置为在回发发生时进行验证,是否执行验证 ID 控件ID Te

在TextBox控件底端添加下划线效果

实现效果: 知识运用: TextBox控件的Font属性 实现代码: private void btn_Display_UnderLine_Click(object sender, EventArgs e) { textBox1.Font = new Font("楷体",22,FontStyle.Underline); } 原文地址:https://www.cnblogs.com/feiyucha/p/10140864.html

在TextBox控件中禁用鼠标右键

实现效果: 知识运用: MouseEventArgs类的Button属性     TextBox控件的ContextMenu属性 实现代码: private void textBox1_MouseDown(object sender, MouseEventArgs e) { if (e.Button == MouseButtons.Right) textBox1.ContextMenu = new ContextMenu(); } 原文地址:https://www.cnblogs.com/fei

C#控件方法及属性大全,望补充

C#控件及常用设计整理 1.窗体 常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体. (2) WindowState属性: 用来获取或设置窗体的窗口状态. 取值有三种: Normal (窗体正常显示). Minimized (窗体以最小化形式显示)和 Maximized(窗体以最大化形式显示). (3)StartPosition属性:用来获取或设置运行时窗体的起始位置. (4)Text属性:该属性是一个字符串属性,用来设置或返回在窗口标题栏中显示的

.NET中TextBox控件设置ReadOnly=true后台取不到值三种解决方法

.NET中TextBox控件设置ReadOnly=true后台取不到值三种解决方法 当TextBox设置了ReadOnly=true后要是在前台为控件添加了值,后台是取不到的,值为空,多么郁闷的一个问题经过尝试,发现可以通过如下的方式解决这个问题.感兴趣的朋友可以了解下 当TextBox设置了ReadOnly="true" 后,要是在前台为控件添加了值,后台是取不到的,值为“空” 原理没想通,说不清楚微软是出于什么考虑的,不过有时是要我们能通过前台脚本来填充值,并不希望用户修改其控件内

验证标题是否存在(TextBox控件失去焦点验证)

首先解释两个属性, AutoPostBack 属性用于设置或返回当用户在 TextBox 控件中按 Enter 或 Tab 键时,是否发生自动回传到服务器的操作. 如果把该属性设置为 TRUE,则启用自动回传,否则为 FALSE.默认是 FALSE. ontextchanged:失去焦点可以出发事件的一个东西 <asp:TextBox ID="txtTitle" runat="server" Width="400px" Validation

ASP.Net TextBox控件只允许输入数字

原文:ASP.Net TextBox控件只允许输入数字 1.1.在Asp.Net TextBox 控件的 OnKeyPress 事件中指定输入键盘码必须为数字: <asp:TextBox ID="TextBox" runat="server" OnKeyPress="if(((event.keyCode>=48)&&(event.keyCode <=57))||(event.keyCode==46)) {event.ret

ASP.NET Button控件的UseSubmitBehavior属性引发的血案

这里先不说标题上的UseSubmitBehavior属性是什么,先说下面这种情况. 通常,在我们写一个表单页面的时候,最下方会有"提交"和"返回"字样的两个按钮.顾名思义,它们的功能大家都知道,但是一般情况下我们会给表单的内容加上一些验证,这样就出现了一个问题.因为两个按钮是服务器控件(有runat="Server"属性),所以点击按钮之后会先进行验证(无论这里你用的是前台的jQuery.validate验证或者是ASP.NET自带的后台验证控件