今天用到ListView控件,这里总结一下ListView控件绑定DataTable的方法
下面需要特别注意的是,绑定的过程中实现绑定控件的column的属性,再进行item的绑定。
与DataGridView不同的是,不能直接使用DataSourse绑定,
再者,绑定第一个Items的时候一定要实例化一个Item进行单独绑定,因为第一个Item与后面的不用即Item与SubItem的区别,下面的代码中也给出了相应的注释
- private void LoadData()
- {
- string sql = @"select * from room";
- DataTable dt = DBUtil.getDataTable(sql);
- this.listView1.Columns.Clear(); //好习惯,先清除再添加保证数据的一致性
- this.listView1.Columns.Add("roomid");
- this.listView1.Columns.Add("typeids");
- this.listView1.Columns.Add("price");
- this.listView1.Items.Clear();
- int length = dt.Rows.Count;
- for (int i = 0; i < length; i++)
- {
- ListViewItem lvi = new ListViewItem(dt.Rows[i]["roomid"].ToString()); //ListView的第一个Item作为主项需要单独添加
- string typeid = dt.Rows[i]["typeids"].ToString();
- switch (typeid)
- {
- case "1":
- lvi.ImageIndex = 0; //设置每个Item类型绑定的图片类型
- break;
- case "2":
- lvi.ImageIndex = 1;
- break;
- case "3":
- lvi.ImageIndex = 2;
- break;
- default:
- break;
- }
- lvi.SubItems.Add(dt.Rows[i]["typeids"].ToString()); //后面添加的Item都为SubItems ,即为子项
- lvi.SubItems.Add(dt.Rows[i]["price"].ToString());
- this.listView1.Items.Add(lvi);//最后进行添加
- }
- }