• 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);
     
    分类: C#
  • 相关阅读:
    mysql 库,表,数据操作
    mysql 初识数据库
    MySQL 索引 视图 触发器 存储过程 函数
    MySQL 事物和数据库锁
    MySQL 约束和数据库设计
    MySQL 创建千万集数据
    MySQL 各种引擎
    求1,1,2,3,5,8,13 斐波那契数列第N个数的值
    WEB前端研发工程师编程能力成长之路(1)
    XML DOM
  • 原文地址:https://www.cnblogs.com/jiangyunfeng/p/10594253.html
Copyright © 2020-2023  润新知