[系列文章]上传文件管理控件v2
一、引言:
开发v1的时候,遇到很多困难(因为我是新手),于是就上网找了一些资料。
其中,这篇《数据绑定的总结 》文章(http://www.cnblogs.com/qingtianyzl/articles/351012.html)被我看到了,里面有把数组绑定到DataGrid的方法。将里面的一部分代码复制过来,修改一下,就完成了基本的功能。
二、基本原理
dataGrid是asp.net 1.x中用来显示网格式数据的服务器控件,可能通过绑定的方式,把DataTable(数据表)里的内容放置到dataGrid。
那么DataTable是哪来的呢?最基本的来源,是通过连接数据库,打开表获得。(这也是大多数课本上讲的)那么,如果像我这样,所要展示的不是来自于数据库的内容怎么办?我就想到,能不能把数组绑定的dataGrid上呢?在网上找了一些资料,没有结果,却从上面提到的那篇文章里找到了另外的思路:用程序生成一个空的DataTable,再创建Field(在asp.net里叫做列DataColumn),然后把数据填充进去。
晴天,在代码里的注释说得很详细,所以我这里就不我啰嗦了。
三、附源代码
1
<%@ Control Language="C#" ClassName="ListUpload_v2" %>
2
<%@ Import Namespace="System.IO" %>
3
<%@ Import namespace="System.Data" %>
4
5
<script runat="server">
6
/****************************************************************
7
**上传文件管理控件
8
**文件名:ListUpload_v2.ascx
9
**Copyrigth(c) 2008-2010 *************** 柳城别日 xpnew.cnblogs.com
10
**文件编号:
11
**创建人:柳城别日
12
**日期:2008年5月22日
13
**修改人:柳城别日
14
**日期:2008年5月22日
15
* 描述:用来管理上传文件,支持列表、删除
16
**/
17
18
//
19
20
/* class ListUpload2
21
{
22
}
23
*
24
*
25
* */
26
// 类内部初始化
27
private string _strDir = @"~/Upload/";
28
29
30
public string strDir//通过这个属性,可以设置控件所要管理的目录
31
{
32
get
33
{
34
return _strDir;
35
}
36
set
37
{
38
_strDir = value;
39
}
40
}
41
42
protected void Page_Load(object sender, EventArgs e)
43
{
44
if (!Page.IsPostBack)
45
{
46
47
//--------------------------------
48
//下面是从网上找到的代码:
49
50
DataTable dt = new DataTable();
51
//dt为声明一个表
52
53
DataRow dr;
54
//表示Table中行的数据
55
56
dt.Columns.Add(new DataColumn("IntegerValue", typeof(Int32)));
57
dt.Columns.Add(new DataColumn("StringValue", typeof(string)));
58
dt.Columns.Add(new DataColumn("DateTimeValue", typeof(DateTime)));
59
dt.Columns.Add(new DataColumn("BooleanValue", typeof(bool)));
60
//Columns为取值该表列的集合,
61
//Add.为该表添加到列的集合 DataColumn为列框架
62
//后面是列头的标题,后面表示该列的数据类型
63
64
65
66
for (int i = 1; i <= 9; i++)
67
{
68
69
dr = dt.NewRow();
70
//创建与该表具有相同框架新的数据行
71
72
73
dr[0] = i;
74
dr[1] = "Item " + i.ToString();
75
dr[2] = DateTime.Now;
76
dr[3] = (i % 2 != 0) ? true : false;
77
//为数据行添加数值
78
dt.Rows.Add(dr);
79
//把获得数值的指定的行加到该表的集合
80
}
81
82
// dataGrid1.DataSource = new DataView(dt);
83
//把该表作为数据源 放到dataGrid1中
84
// dataGrid1.DataBind();//数据绑定被我注释了
85
86
87
//网上的代码结束
88
//------------------
89
90
//-------------------我自己的代码开始
91
92
DataTable FileList = new DataTable();
93
//FileList为声明一个表
94
95
DataRow FileItem;
96
//表示Table中行的数据
97
98
99
FileList.Columns.Add(new DataColumn("选择", typeof(bool)));
100
FileList.Columns.Add(new DataColumn("文件名", typeof(string)));
101
FileList.Columns.Add(new DataColumn("大小(字节)", typeof(Int32)));
102
FileList.Columns.Add(new DataColumn("上传日期", typeof(DateTime)));
103
//Columns为取值该表列的集合,
104
//Add.为该表添加到列的集合 DataColumn为列框架
105
//前面是列头的标题,后面表示该列的数据类型----这是别人的注释
106
//我认为前面不单单是标题那么简单,在v4里后详细地说明
107
108
109
string dirPath = Server.MapPath(strDir);
110
DirectoryInfo Dir = new DirectoryInfo(dirPath);
111
FileInfo[] arrFiles = Dir.GetFiles();
112
113
foreach (FileInfo f in arrFiles)
114
{
115
FileItem = FileList.NewRow();
116
//创建与该表具有相同框架新的数据行
117
FileItem[0] = false;
118
FileItem[1] = f.Name;
119
FileItem[2] = f.Length;
120
FileItem[3] = f.LastWriteTime;
121
//为数据行添加数值
122
123
FileList.Rows.Add(FileItem);
124
//把获得数值的指定的行加到该表的集合
125
126
}
127
128
dataGrid2.DataSource = new DataView(FileList);
129
//把该表作为数据源 放到dataGrid2中
130
dataGrid2.DataBind();
131
//绑定
132
}
133
134
}
135
136
137
138
</script>
139
140
<asp:DataGrid ID="dataGrid2" runat="server" BorderColor="black" BorderWidth="1" CellPadding="3"
141
CellSpacing="0" GridLines="Both" HeaderStyle-BackColor="#aaaadd" >
142
</asp:DataGrid>
143
<%@ Control Language="C#" ClassName="ListUpload_v2" %>2
<%@ Import Namespace="System.IO" %>3
<%@ Import namespace="System.Data" %>4

5
<script runat="server">6
/**************************************************************** 7
**上传文件管理控件8
**文件名:ListUpload_v2.ascx 9
**Copyrigth(c) 2008-2010 *************** 柳城别日 xpnew.cnblogs.com10
**文件编号:11
**创建人:柳城别日12
**日期:2008年5月22日13
**修改人:柳城别日14
**日期:2008年5月22日15
* 描述:用来管理上传文件,支持列表、删除16
**/17

18
//19

20
/* class ListUpload221
{22
}23
* 24
*25
* */26
// 类内部初始化27
private string _strDir = @"~/Upload/";28
29
30
public string strDir//通过这个属性,可以设置控件所要管理的目录31
{32
get33
{34
return _strDir;35
}36
set37
{38
_strDir = value;39
}40
}41
42
protected void Page_Load(object sender, EventArgs e)43
{44
if (!Page.IsPostBack)45
{46

47
//--------------------------------48
//下面是从网上找到的代码:49
50
DataTable dt = new DataTable();51
//dt为声明一个表52

53
DataRow dr;54
//表示Table中行的数据55

56
dt.Columns.Add(new DataColumn("IntegerValue", typeof(Int32)));57
dt.Columns.Add(new DataColumn("StringValue", typeof(string)));58
dt.Columns.Add(new DataColumn("DateTimeValue", typeof(DateTime)));59
dt.Columns.Add(new DataColumn("BooleanValue", typeof(bool)));60
//Columns为取值该表列的集合,61
//Add.为该表添加到列的集合 DataColumn为列框架62
//后面是列头的标题,后面表示该列的数据类型63

64

65

66
for (int i = 1; i <= 9; i++)67
{68

69
dr = dt.NewRow();70
//创建与该表具有相同框架新的数据行71

72

73
dr[0] = i;74
dr[1] = "Item " + i.ToString();75
dr[2] = DateTime.Now;76
dr[3] = (i % 2 != 0) ? true : false;77
//为数据行添加数值78
dt.Rows.Add(dr);79
//把获得数值的指定的行加到该表的集合80
}81

82
// dataGrid1.DataSource = new DataView(dt);83
//把该表作为数据源 放到dataGrid1中84
// dataGrid1.DataBind();//数据绑定被我注释了85
86

87
//网上的代码结束88
//------------------89
90
//-------------------我自己的代码开始91
92
DataTable FileList = new DataTable();93
//FileList为声明一个表94

95
DataRow FileItem;96
//表示Table中行的数据97
98
99
FileList.Columns.Add(new DataColumn("选择", typeof(bool)));100
FileList.Columns.Add(new DataColumn("文件名", typeof(string)));101
FileList.Columns.Add(new DataColumn("大小(字节)", typeof(Int32)));102
FileList.Columns.Add(new DataColumn("上传日期", typeof(DateTime)));103
//Columns为取值该表列的集合,104
//Add.为该表添加到列的集合 DataColumn为列框架105
//前面是列头的标题,后面表示该列的数据类型----这是别人的注释106
//我认为前面不单单是标题那么简单,在v4里后详细地说明107

108
109
string dirPath = Server.MapPath(strDir);110
DirectoryInfo Dir = new DirectoryInfo(dirPath);111
FileInfo[] arrFiles = Dir.GetFiles();112

113
foreach (FileInfo f in arrFiles)114
{115
FileItem = FileList.NewRow();116
//创建与该表具有相同框架新的数据行117
FileItem[0] = false;118
FileItem[1] = f.Name;119
FileItem[2] = f.Length;120
FileItem[3] = f.LastWriteTime;121
//为数据行添加数值122

123
FileList.Rows.Add(FileItem);124
//把获得数值的指定的行加到该表的集合125

126
}127

128
dataGrid2.DataSource = new DataView(FileList);129
//把该表作为数据源 放到dataGrid2中130
dataGrid2.DataBind();131
//绑定132
}133

134
}135

136

137

138
</script>139

140
<asp:DataGrid ID="dataGrid2" runat="server" BorderColor="black" BorderWidth="1" CellPadding="3"141
CellSpacing="0" GridLines="Both" HeaderStyle-BackColor="#aaaadd" >142
</asp:DataGrid>143

流浪是注定的宿命;
漂泊是无尽的轮回。
漂泊是无尽的轮回。


浙公网安备 33010602011771号