• C# DataGridView绑定List对象时,利用BindingList来实现增删查改


         当DataGridView的DataSource是DataTable的时候,DataTable的数据改变时,DataGridView的数据会随之改变,无需重新绑定到DataGridView。  当DataGridView的DataSource是泛型List,当List的数据改变时,则需要先将DataGridView的DataSource设置为new List<T>(),再将改变后的List<T>赋给DataGridView的DataSource。绑定List时,注意:切莫将DataGridView的DataSource设置为Null,否则会破坏DataGridView的列结构。

         如果要对绑定在DataGridView中的List<T>进行数据的添加删除,先要把List<T>转换成BindingList<T>,再进行绑定:DataGridView.DataSource=new BindingList<T>(new List<T>)。否则的话会产生许多意想不到的错误。 如:初始绑定空数据后再添加数据绑定后,却取不到DataGridView.CurrentCell属性。

      IList<T> list= new List<T>();

      DataGridView.DataSource=list;//DataGridView的行不能添加删除

      DataGridView.DataSource=new BindingList<T>(list);//DataGridView的行可以添加删除(只有允许添加行、删除行)

    示例代码:

    public partial class ucServer : UserControl
         {
             private List<ServerInfo> serverList;
             private BindingList<ServerInfo> dataBindings;

            public ucServer(List<ServerInfo> serverList)
             {
                 InitializeComponent();
                 if (serverList == null)
                     serverList = new List<ServerInfo>();
                 this.serverList = serverList;
                 dataBindings = new BindingList<ServerInfo>(this.serverList);
             }

            private void ucChecker_Load(object sender, EventArgs e)
             {
                 this.dgParams.DataSource = dataBindings;
             }

            private void llDownloadUrl_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
             {
                 MessageBox.Show("请设置下载地址。");
             }

            private void llHelp_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
             {
                 MessageBox.Show("请设置帮助信息。");
             }

            public bool IsValid()
             {
                 return true;//CheckService.Check(this.component);
             }

            private void btnAdd_Click(object sender, EventArgs e)
             {
                 ServerInfo info = new ServerInfo() {  OSType="Windows", Ports="8000-9999"};

                dataBindings.Add(info);
             }

            private void btnDel_Click(object sender, EventArgs e)
             {
                 //允许删除多行

                DataGridViewSelectedRowCollection rows = this.dgParams.SelectedRows;

                foreach (DataGridViewRow row in rows)
                 {
                     this.dataBindings.RemoveAt(row.Index);
                 }
             }

        }

  • 相关阅读:
    Android简易抽屉效果
    apk 下载并自动安装
    python2.7_1.3_获取远程设备的IP地址
    python2.7_1.2_打印设备名和IPv4地址
    python2.7_1.14_编写一个简单的回显客户端/服务器应用
    python2.7_1.13_编写一个SNTP客户端
    C语言程序转换为Python语言
    5分钟弄懂Docker!
    让正则表达式变简单(PythonVerbalExpressions)
    python sqlalchemy-migrate 使用方法
  • 原文地址:https://www.cnblogs.com/vveiliang/p/8522001.html
Copyright © 2020-2023  润新知