今天用到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);//最后进行添加
}
}