根据自己的应用方式和在网上搜寻的资料,整理一下ListView控件的应用。

ListView控件可以直观的显示数据,操作很方便简单的特点。

一,ListView添加表头的两种方法:

1,直接在控件的任务中的编辑列中添加,Name是绑定的code值,Text是表头的显示值。

2,在后台代码中添加表头,代码如下:

ColumnHeader ch = new ColumnHeader();//声明表头,并创建对象
                    ch.Text = "111";  //表头的显示名称
                    ch.Name = "222";  //表头绑定的code值
                    ch.Width = 100;   //表头宽度
                    this.listView_EH.Columns.Add(ch);  //添加表头到ListView中

如果要添加第二列,可以按照上面的方式添加。

二,ListView绑定数据的方法

1,获取dt或ds后foreach遍历每一行记录,然后给ListView的相对于的列附值。这个方法数据源和绑定方法不能分离

注:注意表头显示的信息和绑定信息的顺序。绑定的顺序既是显示的顺序

代码如下:

//绑定ListView,显示数据
        private void SetListView()
        {
            this.listView_EH.Items.Clear();
            DataSet ds = qt.GetQuestionTypeInfo();
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
            {
                foreach (DataRow dr in ds.Tables[0].Rows)
                {
                    string strQuestionTypeID = dr["QuestionTypeID"].ToString();
                    string strQuestionTypeName = dr["QuestionTypeName"].ToString();
                    int intsort = Convert.ToInt32(dr["sort"].ToString());
                    string strAnswerTypeName = dr["AnswerTypeName"].ToString();
                    ListViewItem lvItem = new ListViewItem();
                    lvItem.Text = intsort.ToString();
                    lvItem.Tag = dr;
                    lvItem.SubItems.Add(strQuestionTypeName.ToString());
                    lvItem.SubItems.Add(strAnswerTypeName.ToString());
                    this.listView_EH.Items.Add(lvItem);
                }
            } 
        }

然后ListView控件读取当前选择行的代码时可以这样

//读取ListView的某行的信息
        private void listView_EH_Click(object sender, EventArgs e)
        {
            if (this.listView_EH.Items.Count <= 0) return;
            if (this.listView_EH.SelectedItems.Count <= 0) return;
            int index = this.listView_EH.SelectedItems[0].Index;
            if (index < 0) return;
            DataRow dr = (DataRow)(this.listView_EH.Items[index].Tag);
            this.txt_questiontypeID.Text = dr["QuestionTypeID"].ToString();
            this.num_sort.Text = dr["sort"].ToString();
            this.txt_questiontypename.Text = this.listView_EH.SelectedItems[0].SubItems[1].Text.ToString();
            this.com_answertype.Text = dr["AnswerTypeName"].ToString();
        }

2,获取dt或者ds后,然后for数据源的每一行的每一列给ListView列附值。这个方法数据源和绑定方法可以分离,但是绑定的时候要注意select的数据源的顺序和显示的顺序是一样的,还有就是显示列和表头对应。注意第二次循环时表头的对应。

代码如下:

//绑定ListView,显示数据
        private void SetListView()
        {
            this.listView_EH.Items.Clear();
            DataSet ds = qt.GetQuestionTypeInfo();
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
            {
                ListViewItem lv = null;
                for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
                {
                    lv = new ListViewItem(ds.Tables[0].Rows[i][1].ToString());
                    lv.Tag = ds.Tables[0].Rows[i][0].ToString();
                    for (int j = 2; j < ds.Tables[0].Columns.Count; j++)
                    {
                        lv.SubItems.Add(ds.Tables[0].Rows[i][j].ToString());
                    }
                    this.listView_EH.Items.Add(lv);
                }
               
            } 
        }
然后ListView控件读取当前选择行的代码时这样
//读取ListView的某行的信息
        private void listView_EH_Click(object sender, EventArgs e)
        {
            this.num_sort.Text = this.listView_EH.SelectedItems[0].SubItems[0].Text;
            this.txt_questiontypename.Text = this.listView_EH.SelectedItems[0].SubItems[1].Text;
            this.com_answertype.Text = this.listView_EH.SelectedItems[0].SubItems[2].Text;
        }

三,解决ListView显示的时候隐藏一列,当读取某行的信息时,可以显示隐藏列的值。

该问题描述的是当ListView在第二中方法绑定时,显示的时候将某列值隐藏,当读取改行的信息时可以读取隐藏值。

在第二种方法中。lv = new ListViewItem(ds.Tables[0].Rows[i][1].ToString());是ListView中显示的第一列数据。

而lv.Tag=ds.Tables[0].Rows[i][0].ToString();就是隐藏列。

当读取改行数据的时候即可通过

this.txt_questiontypeID.Text = this.listView_EH.SelectedItems[0].Tag.ToString();

获得该隐藏列的值。

//Tag可以付任何对象的值,比如字符串,数值型...我经常用该项保存调用数据库时不用显示的编号信息。