zoukankan      html  css  js  c++  java
  • 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);
                 }
             }

        }

  • 相关阅读:
    Ocelot一款.NET下的API网关介绍
    【Core】.NET Core 部署( Docker + CentOS)
    VS2019添加git源代码管理
    sql两个表组合到一起,字符串拼接后放在最后一列上
    sqlserver取随机数随机取数
    delphi时间戳(10位)
    消息 7356,级别 16,状态 1,第 1 行 链接服务器 "downloadschoolcardinfo" 的 OLE DB 访问接口 "OraOLEDB.Oracle" 为列提供的元数据不一致。对象 ""VIEW_ZJK"."V_QDXQHIS_RYXX"" 的列 "XZZ" (编译时序号为 9)在编译时有 1 的 "LENGTH",但在运行时有 2。
    sqlserver简单的组合串
    Delphi提示:List Index out Of bounds(5)
    SQLserver简单的竖向转横向
  • 原文地址:https://www.cnblogs.com/vveiliang/p/8522001.html
Copyright © 2011-2022 走看看