20150226—C# winform中的ListView解析
ListView在WinForm中多用于表的构建,可以直观的显示表的信息,其格式如同SQL的表
这是他的位置,在公共控件中:
Listview的几个重要属性:Columms(集合)、Groups(集合)、Items(集合)、View(视图)、以及Items中的SubItems(集合)
其中View共有5种样式,常用选项为Details(详细资料)
下图划分了ListView中Details样式下,各行各列的集合名。
Columns集合:需要在其中编辑列名,第一行(列名)
Items集合,第一列的第二行开始,这一列是单独的一个集合
SubItems集合:从第二列第二行开始,每一行为一个集合。
注:SubItems在Items集合编辑器的属性一栏中
了解了ListView的构造再来看看如何使用代码往里添加数据。
1.创建一个WinForm,在表中画出ListView,并修改ListView的属性:
View修改为Details。
在属性--行为--Columns集合中添加成员,并把Text分别修改为学号,姓名,性别,生日,班级
如图:
新建一个类:xuesheng
public class xuesheng
{
//定义变量并且封装。
private string _Sno; public string Sno
{
get { return _Sno; }
set { _Sno = value; }
}
private string _Sname; public string Sname
{
get { return _Sname; }
set { _Sname = value; }
}
private string _Ssex; public string Ssex
{
get { return _Ssex; }
set { _Ssex = value; }
}
private string _Sbirthday; public string Sbirthday
{
get { return _Sbirthday; }
set { _Sbirthday = value; }
}
private string _Class; public string Class
{
get { return _Class; }
set { _Class = value; }
} public DataTable goujianbiao()//在C#中创建一个临时的数据表
{
DataTable dt = new DataTable();//初始化数据表,需要引用using System.Data;
//添加表的 列
DataColumn sno = new DataColumn("sno");// 表的列 ("列名")
dt.Columns.Add(sno);
DataColumn sname =new DataColumn("sname");
dt.Columns.Add(sname);
DataColumn ssex=new DataColumn("ssex");
dt.Columns.Add(ssex);
DataColumn sbirthday=new DataColumn("sbirthday");
dt.Columns.Add(sbirthday);
DataColumn sclass=new DataColumn("sclass");
dt.Columns.Add(sclass); //创建 表的 行
DataRow row1=dt.NewRow();
//在行中填入数据
row1["sno"]="";
row1["sname"]="张三";
row1["ssex"]="男";
row1["sbirthday"]="1987-05-15";
row1["sclass"]="2012班";
dt.Rows.Add(row1);//将行Row1填入到表dt的行的集合中
return dt;//返回 数据表 对象
}
在From_Load的函数中输入以下代码:
private void Form3_Load(object sender, EventArgs e)
{
xuesheng xx = new xuesheng();//如果不再同一个命名空间中不要忘记引用命名空间
DataTable dt = xx.goujianbiao();//调用方法来构建出datatable表数据
for (int i = ; i < dt.Rows.Count; i++)//dt.Rows.Count 获取数据表dt中行的个数
{
DataRow dr = dt.Rows[i];//构建的数据表中一行的数据 ,行的集合,这里只有一行数据,
//根据列名找到这一行的元素并添加到Items集合中,第一列第二行,这里这个Items集合只有一个元素
listView1.Items.Add(dr["sno"].ToString());
//根据列名将SubItems集合的元素分别添加进去,第二列第二行开始,集合中的元素按行排列
listView1.Items[i].SubItems.Add(dr["sname"].ToString());
listView1.Items[i].SubItems.Add(dr["ssex"].ToString());
listView1.Items[i].SubItems.Add(dr["sbirthday"].ToString());
listView1.Items[i].SubItems.Add(dr["sclass"].ToString());
}
}
最后运行结果:
20150226—C# winform中的ListView解析的更多相关文章
- C#winform中ListView的使用
使用ListView模仿Windows系统的资源管理器界面,实现文件(夹)的浏览.重命名.删除及查询等功能,主要功能界面展示如下: 1.MainForm.cs及MainForm.Designer.cs ...
- winform中如何在多线程中更新UI控件--ListView实时显示执行信息
1.在winform中,所有对UI的操作,都得回到UI线程(主线程)上来,才不会报错 线程间操作无效: 从不是创建控件的线程访问它. 2.在winform中,允许通过Control.invoke对控件 ...
- 在WinForm中使用委托来在其他线程中改变控件的显示
假设winform中有两个控件: 1.ListView用来显示进度的文本提示,ID:listView_progressInfo 2.ProgressBar用来显示进度,ID:progressBar1 ...
- WinForm中 Asp.Net Signalr消息推送测试实例
p{ text-align:center; } blockquote > p > span{ text-align:center; font-size: 18px; color: #ff0 ...
- 转载:WinForm中播放声音的三种方法
转载:WinForm中播放声音的三种方法 金刚 winForm 播放声音 本文是转载的文章.原文出处:http://blog.csdn.net/jijunwu/article/details/4753 ...
- 解决在ScrollView中套用ListView显示不正常
最近在设计Android程序时,因为需要在ScrollView中添加一个ListView列表来显示一些信息.刚开始并没有想太多,但添加进去后才发现ListView不论怎样定义都只能显示一行,显示效果很 ...
- java中采用dom4j解析xml文件
一.前言 在最近的开发中用到了dom4j来解析xml文件,以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4 ...
- C# Winform 中如何实现音乐播放和视频播放
C# Winform 中如何实现音乐播放和视频播放 namespace WindowsFormsApplication1 { public partial class Form2 : Form { ...
- 另一种在WINFORM中使用XNA的方法
之前在写化学分子模型制作程序的时候,使用一种方法,将WINFORM控件嵌入到XNA窗体中,从而实现了即使用WINFORM窗体控件又使用XNA.最近在写另一个物理运动学课件制作程序,同样使用XNA,但从 ...
随机推荐
- 两点C#的propertyGrid的使用心得
最近接触C#的PropertyGrid比较多,得到了两个小心得记录一下. 第1点是关于控制PropertyGrid中属性的只读属性的. 我遇到的问题是这样的,我需要在运行时根据SVN的状态动态控制Pr ...
- iOS开发——测试篇&breakpoints、lldb 和 chisel 的详解
breakpoints.lldb 和 chisel 的详解 Breakpoints BreakPoint分类 breakpoint也是有分类的,我这里的文章内大致按使用的方式分为了 Normal Br ...
- 好记心不如烂笔头之JQuery学习,第二章
jQuery获取元素不需要担心元素不存在而报错,但是无论怎样 $("#xxx") 是一定会有返回值的,无论存不存在元素,那么依然是要对元素做判断的,判断的方法常见两种 1.看返回的 ...
- 终端I/O之非规范模式
关闭termios结构中c_lflag字段的ICANON标志就使终端处于非规范模式.在非规范模式中,输入数据并不组成行,不处理下列特殊字符:ERASE/KILL/EOF/NL/EOL/EOL2/CR/ ...
- LeetCode38 Count and Say
The count-and-say sequence is the sequence of integers beginning as follows:1, 11, 21, 1211, 111221, ...
- 小白日记52:kali渗透测试之Web渗透-HTTPS攻击(Openssl、sslscan、sslyze、检查SSL的网站)
HTTPS攻击 全站HTTPS正策划稿那位潮流趋势 如:百度.阿里 HTTPS的作用 CIA 解决的是信息传输过程中数据被篡改.窃取 [从中注入恶意代码,多为链路劫持] 加密:对称.非对称.单向 HT ...
- scala基础备忘
声明一个变量 声明一个常量 显式指定类型 定义一个main函数 package org.admln.scala class HelloScala { } object HelloScala { def ...
- mysql前n条查询
可以利用——LIMIT——来完成这项功能. LIMIT可以实现top N查询,也可以实现M至N(某一段)的记录查询,具体语法如下: SELECT * FROM MYTABLE ORDER BY AFI ...
- nodejs的mysql模块学习(八)关闭连接池
关闭连接池 可以用pool.end()关闭连接池 pool.end(function (err) { // 所有的连接都已经被关闭 }); 当关闭之后pool将不可以getconnection()
- oracle日志总结
①. Oracle日志分类: Alert log files--警报日志 , redo log 重做日志(记录数据库的更改,Trace files--跟踪日志(用户和进程) Oracle的重做日志(r ...