zoukankan      html  css  js  c++  java
  • 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);
  • 相关阅读:
    bean的注入方式
    Spring中的IOC
    BeanFactory和ApplicationContext的区别
    mysql出现锁表 com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction
    centos防火墙
    sql中union和union all的区别
    Sql语句中IN和exists的区别及应用
    ROLLUP,CUBE,GROUPPING详解
    通过WinRM在本机执行云服务器脚本,更新git代码
    Sqlserver2012评估期已过问题解决
  • 原文地址:https://www.cnblogs.com/sxypeace/p/5640647.html
Copyright © 2011-2022 走看看