• C# 中DataGridView 绑定List<T>做数据源的操作问题


    若想将 List<T>作为DataGridView的数据源,然后后续还想继续操作的话,需要将List<T>赋值给BindingList对象,

    然后直接将BindingList赋值给DataGridView.DataSource, 如此直接操作BindingList对象时,DataGridView的结果会动态随之更新。

    1,绑定

    List<UserClass>  listUserClass = new List<UserClass>();
    BindingList   BList<
    UserClass> ;
    listUserClass
    = this.UserMethodInitList(); //初始化

    BList = new BindingList<UserClass>( listUserClass);//赋值给BindingList对象,Form全局变量
    this.DataGridView1.DataSource = BList; //将DataGridView里的数据源绑定成BindingList

    2, 获取当前选定的行

    //获取行对象后
    List<UserClass> modiObj = this.DataGridView1.CurrentRow.DataBoundItem as UserClass;
    

    3, 修改当前行

    //获取行对象后
    List<UserClass> modiObj = this.DataGridView1.CurrentRow.DataBoundItem as UserClass;
    
    modiObj .cost = 10; //修改值
    
    int  pos = this.DataGridView1.CurrentRow.Index; //记位置
    
    this.BList.RemoveAt( pos); //删除行
    
    this.BList.Insert( pos, modiObj );//添加修改后的行到指定位置, 不指定位置默认添加到最后

    4,删除行

    int  pos = this.DataGridView1.CurrentRow.Index; //记位置
    
    this.BList.RemoveAt( pos); //删除行,操作BindingList对象即可更新DataGridview

     5,删除多行

                //允许删除多行
    
                DataGridViewSelectedRowCollection rows = this.DataGridView1.SelectedRows;
    
                foreach (DataGridViewRow row in rows)
    
                {
    
                    this.BList.RemoveAt(row.Index);
    
                }

    6, 返向转换

    BindingList<UserClass> Blist = (BindingList<UserClass>) this.DataGridView1.DataSource;
    
    
    List<UserClass> list1 = List<UserClass>( Blist);
  • 相关阅读:
    第二章第1节: 2020.04.22 智能互联网之核心技术实践篇【一】
    分布式和集群理解
    CMDB了解
    Git常用命令
    brpc支持多协议
    数据库性能瓶颈了解
    接口理解
    mysql explain与索引
    InnoDB的redo log学习
    数据库抖动原因了解
  • 原文地址:https://www.cnblogs.com/sxypeace/p/5640647.html
Copyright © 2020-2023  润新知