c# 如何将RadioButton与DataTable数据进行绑定_C#教程

Control类有一个公共的属性是DataBindings,它可以将控件的属性与其他的数据绑定在一起。我接触到的有将两个控件的数据绑定、将控件的属性与DataTable绑定。以下说说在将DataTable与RadioButton绑定的过程中出现的问题。

界面上有两个RadioButton,rdoA和rdoB,以及一个显示dt数据的Button;后台定义一个私有变量DataTable dt。界面初始化完成后,将rdo与dt的值绑定起来。

复制代码 代码如下:

DataTable dt = null;
public DataBinding2()
{
InitializeComponent();
dt = new DataTable();
dt.Columns.Add("A", typeof(bool));
dt.Columns.Add("B", typeof(bool));
dt.Rows.Add(rdoA.Checked, rdoB.Checked);
rdoA.DataBindings.Add("Checked", dt, "A");
rdoB.DataBindings.Add("Checked", dt, "B");
btnDTValue.Click += (a, b) =>
MessageBox.Show(string.Format("A: {0}\r\nB: {1}", dt.Rows[0]["A"], dt.Rows[0]["B"]));
}

到这里,完成思路需要的代码似乎敲完了,进入调试,看看结果。
没有点击任何RadioButton之前,查看dt的数据是正确的。
 
点击rdoA之后,再次查看dt的数据。
 
出现错误了。点击rdoA之后,rdoA的checked状态为true,这点没错,但是rdoA的状态会变成false,为什么绑定的dt里面B的值仍然是true呢??
我们可以仔细的研究Control.DataBindings.Add这个方法。
它有好几个扩展的方法,上面的示例中调用的是

复制代码 代码如下:

public Binding Add(string propertyName, object dataSource, string dataMember)

查看它后台实际执行的是什么函数呢?

复制代码 代码如下:

public Binding Add(string propertyName, object dataSource, string dataMember)
{
return this.Add(propertyName, dataSource, dataMember, false, this.DefaultDataSourceUpdateMode,
null, string.Empty, null);
}

继续追查this.DefaultDataSourceUpdateMode的选项。在微软的官方说明文字中可以看到这样一段
"在未指定 DataSourceUpdateMode 的 Binding 添加到集合中的情况下,将使用 DefaultDataSourceUpdateMode 属性。对于 Windows 窗体控件,此默认值是 OnValidation"。
接下来的问题是,点击rdoA之后,是否会执行rdoB控件的OnValidation函数呢?于是在另一个项目里做了测试,(详细的测试方法可以看这里)两个radioButton,初始时,rdoA为true,rdoB为false。点击rdoB,会发现执行的事件包括:
1, rdoA, 事件:CheckedChanged
2, rdoB, 事件:CheckedChanged
3, rdoB, 事件:Validating
4, rdoB, 事件:Validated
由上面的结果可以看出,rdoA的验证事件并不会触发。也就是说rdoA此刻的Checked值并不会绑定到dt里面。
问题出在这里。找到问题之后修改起来就非常简单了。Add调用另一个重载的方法,输入DataSourceUpdateMode。
rdoA.DataBindings.Add("Checked", dt, "A", false, DataSourceUpdateMode.OnPropertyChanged);
rdoB.DataBindings.Add("Checked", dt, "B", false, DataSourceUpdateMode.OnPropertyChanged);

时间: 2024-11-02 14:13:27

c# 如何将RadioButton与DataTable数据进行绑定_C#教程的相关文章

C#实现集合转换成json格式数据的方法_C#教程

本文实例讲述了C#实现集合转换成json格式数据的方法.分享给大家供大家参考,具体如下: /// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"></param> /// <returns></returns> public static string ToJson(DataTable dt) { if (dt != null

C#简单查询SQLite数据库是否存在数据的方法_C#教程

本文实例讲述了C#简单查询SQLite数据库是否存在数据的方法.分享给大家供大家参考,具体如下: //sqlite数据库驱动组件 using System.Data.SQLite; //插入数据库函数 int SQLquery(string sql) { try { //打开数据库 SQLiteConnection conn = new SQLiteConnection(); SQLiteConnectionStringBuilder connstr = new SQLiteConnection

C#读写操作app.config中的数据应用介绍_C#教程

读语句: 复制代码 代码如下: String str = ConfigurationManager.AppSettings["DemoKey"]; 写语句: 复制代码 代码如下: Configuration cfa = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); 2 cfa.AppSettings.Settings["DemoKey"].Value = "D

浅谈C#各种数组直接的数据复制/转换_C#教程

之前做Opengl程序,用的的C#的SharpGL这个库,里面有各种奇怪绑定的函数,比如原型为: void glInterleavedArrays(uint format, int stride, void * pointer); 的函数被他绑定成: private static extern void glInterleavedArrays(uint format, int stride, int[] pointer); 然后我就被逼着学习了各种float[] 转 int[] 的方法,比较他们

C#使用Jquery zTree实现树状结构显示 异步数据加载_C#教程

C#使用Jquery zTree实现树状结构显示_异步数据加载 JQuery-Ztree下载地址:https://github.com/zTree/zTree_v3 JQuery-Ztree数结构演示页面:  http://www.treejs.cn/v3/demo.php 关于zTree的详细解释请看演示页面,还有zTree帮助Demo.  下面简要讲解下本人用到的其中一个实例(直接上关键代码了): 异步加载节点数据:  A-前台: <link href="zTree_v3-master

asp.net将datatable数据转换为xml下载

问题描述 asp.net将datatable数据直接转换为xml并下载吗?现在的程序是将datatable数据转换为xml文件并保持在服务器,然后再下载.不知道能跳过"将datatable生成xml文件保存在服务器"这一步,直接将datatable转换成xml文件下载吗? 解决方案 解决方案二:直接将xml字符串response出来就可以了啊,指定返回的是xml,你查下文件下载,思路一样的解决方案三:有点不能理解将datatable数据转换为xml文件并保持在服务器和将datatabl

怎么吧datatable数据写到内存中?

问题描述 怎么吧datatable数据写到内存中? 解决方案 解决方案二:缓存吧解决方案三:如果在当前页面用的话就用ViewState吧!解决方案四:本来就在内存中吧,你是要做什么呢?解决方案五:你如果是说在内存中保留的话可以用Cache解决方案六:引用4楼juliohuang的回复: 你如果是说在内存中保留的话可以用Cache 我是用的cache,写到了global.asax中,就是不知道添加一条数据库者个缓存能不能得到我新添加的数据?

利用ASP.NET MVC和Bootstrap快速搭建个人博客之后台dataTable数据列表_实用技巧

jQuery dataTables 插件是一个优秀的表格插件,是后台工程师的福音!它提供了针对数据表格的排序.浏览器分页.服务器分页.查询.格式化等功能.dataTables 官网也提供了大量的演示和详细的文档进行说明,为了方便使用,这里进行详细说明. 去官网:https://www.datatables.net/ 下载最新版本是v1.10.12. 在页面引入: <link rel="stylesheet" href="~/Content_Admin/css/boots

asp.net实现导出DataTable数据到Word或者Excel的方法_实用技巧

本文实例讲述了asp.net实现导出DataTable数据到Word或者Excel的方法.分享给大家供大家参考,具体如下: /// <summary>< xmlnamespace prefix ="o" ns ="urn:schemas-microsoft-com:office:office" /> /// 导出DataTable数据到Word或者Excel /// </summary> /// <param name=&q