有了Table,我们对其继承,实现更符合业务要求的类
SaleReport对外封装了对Table的处理细节,使用SaleReport的用户不会感觉到在使用Table类
1
/**////<summary>
2
///描述一个销售报表
3
///</summary>
4
publicclassSaleReport:Table
5

{
6
7
publicSaleReport(stringreportName)
8
:base(reportName,newColumnCollection())
9

{
10
11
this.Columns.Add("序号",typeof(int),0);
12
this.Columns.Add("姓名",typeof(string),null);
13
this.Columns.Add("商品名称",typeof(string),null);
14
this.Columns.Add("日期",typeof(DateTime),null);
15
this.Columns.Add("数量",typeof(double),null);
16
}
17
18
/**////<summary>
19
///报表的名称
20
///</summary>
21
publicstringName
22

{
23
get
24

{
25
returnthis.Name;
26
}
27
}
28
29
/**////<summary>
30
///加入数据
31
///</summary>
32
///<paramname="staff"></param>
33
///<paramname="commodity"></param>
34
///<paramname="cash"></param>
35
publicvoidAddRecord(stringstaff,stringcommodity,doublecash)
36

{
37
Rowrow=this.NewRow();
38
row["序号"]=this.Rows.Count+1;
39
row["姓名"]=staff;
40
row["商品名称"]=commodity;
41
row["日期"]=DateTime.Now;
42
row["数量"]=cash;
43
44
this.Rows.Add(row);
45
}
46
47
/**////<summary>
48
///移除数据
49
///</summary>
50
///<paramname="index"></param>
51
publicvoidRemoveAt(intindex)
52

{
53
this.Rows.RemoveAt(index);
54
}
55
56
/**////<summary>
57
///返回销售报表的销售金额
58
///</summary>
59
///<returns></returns>
60
publicdoubleGetTotal()
61

{
62
doublecash=0;
63
foreach(Rowrowinthis.Rows)
64

{
65
cash+=(double)row["数量"];
66
}
67
returncash;
68
}
69
70
/**////<summary>
71
///返回销售报表的销售金额
72
///</summary>
73
///<paramname="staff">销售员</param>
74
///<returns></returns>
75
publicdoubleGetTotal(stringstaff)
76

{
77
doublecash=0;
78
foreach(Rowrowinthis.Rows)
79

{
80
if((string)row["姓名"]==staff)
81

{
82
cash+=(double)row["数量"];
83
}
84
}
85
returncash;
86
}
87
88
}

/**////<summary>2
///描述一个销售报表3
///</summary>4
publicclassSaleReport:Table5


{6

7
publicSaleReport(stringreportName)8
:base(reportName,newColumnCollection())9


{10

11
this.Columns.Add("序号",typeof(int),0);12
this.Columns.Add("姓名",typeof(string),null);13
this.Columns.Add("商品名称",typeof(string),null);14
this.Columns.Add("日期",typeof(DateTime),null);15
this.Columns.Add("数量",typeof(double),null);16
}17

18

/**////<summary>19
///报表的名称20
///</summary>21
publicstringName22


{23
get24


{25
returnthis.Name;26
}27
}28

29

/**////<summary>30
///加入数据31
///</summary>32
///<paramname="staff"></param>33
///<paramname="commodity"></param>34
///<paramname="cash"></param>35
publicvoidAddRecord(stringstaff,stringcommodity,doublecash)36


{37
Rowrow=this.NewRow();38
row["序号"]=this.Rows.Count+1;39
row["姓名"]=staff;40
row["商品名称"]=commodity;41
row["日期"]=DateTime.Now;42
row["数量"]=cash;43

44
this.Rows.Add(row);45
}46

47

/**////<summary>48
///移除数据49
///</summary>50
///<paramname="index"></param>51
publicvoidRemoveAt(intindex)52


{53
this.Rows.RemoveAt(index);54
}55

56

/**////<summary>57
///返回销售报表的销售金额58
///</summary>59
///<returns></returns>60
publicdoubleGetTotal()61


{62
doublecash=0;63
foreach(Rowrowinthis.Rows)64


{65
cash+=(double)row["数量"];66
}67
returncash;68
}69

70

/**////<summary>71
///返回销售报表的销售金额72
///</summary>73
///<paramname="staff">销售员</param>74
///<returns></returns>75
publicdoubleGetTotal(stringstaff)76


{77
doublecash=0;78
foreach(Rowrowinthis.Rows)79


{80
if((string)row["姓名"]==staff)81


{82
cash+=(double)row["数量"];83
}84
}85
returncash;86
}87

88
}
SaleReport对外封装了对Table的处理细节,使用SaleReport的用户不会感觉到在使用Table类
1
SaleReportreport=newSaleReport("销售台帐");
2
report.AddRecord("Alex","Phone",2600);
3
report.AddRecord("Alex","PC",4560);
4
report.AddRecord("Alex","Table",234);
5
report.AddRecord("Sidney","Phone",2100);
6
report.AddRecord("Sidney","TV",4500);
7
report.AddRecord("Tom","oven",300);
8
report.AddRecord("Leo","oven",240);
9
10
report.Print();
SaleReportreport=newSaleReport("销售台帐");2
report.AddRecord("Alex","Phone",2600);3
report.AddRecord("Alex","PC",4560);4
report.AddRecord("Alex","Table",234);5
report.AddRecord("Sidney","Phone",2100);6
report.AddRecord("Sidney","TV",4500);7
report.AddRecord("Tom","oven",300);8
report.AddRecord("Leo","oven",240);9

10
report.Print();
运行的结果是
序号 姓名 商品名称 日期 数量
1 Alex Phone 2007-2-13 23:19:27 2600
2 Alex PC 2007-2-13 23:19:27 4560
3 Alex Table 2007-2-13 23:19:27 234
4 Sidney Phone 2007-2-13 23:19:27 2100
5 Sidney TV 2007-2-13 23:19:27 4500
6 Tom oven 2007-2-13 23:19:27 300
7 Leo oven 2007-2-13 23:19:27 240

被折叠的 条评论
为什么被折叠?



