| 添加到收藏夹 | 返回目录页 | 上一篇:ASP.NET控件开发之 |
ASP.NET中用哪种方式表格化数据
在开发asp.net站点项目中,经常用表格化的方式显示数据。最常用的可能就是datagrid绑定dataset数据的方式。在做过的软件项目中,有3种表格化数据的典型处理方式。
1、datagrid绑定数据源。这种方式大家用的最多,但是datagrid与ado.net完美的绑定方式,还是让人不爽。清一色的datagrid风格很难适应不同项目的特殊风格,而且在datagrid上做出的个性化处理也会非常的麻烦。
2、用xml(数据)+xsl(样式单)。大家能理解,dataset绑定到datagrid的实现机理不过如此。如图所示,实现这样的一个表格,开发人员可以尽情的设计xsl的风格样式。
2 <tr>
3 <td align="center">
4 <table id="tblcontainer" class="msonormaltable" style="width: 380px; border-collapse: collapse; height: 10px"
5 cellspacing="0" cellpadding="6" border="1" runat="server" bordercolor="#99cccc">
6 <tr>
7 <td colspan="2" align="center">
8 <p><font size="3"><strong><font face="宋体">综合管理部人员职务</font></strong></font></p>
9 </td>
10 </tr>
11 <tr>
12 <td align="center" bgcolor="#003399"><font size="2" color="#ffffff"><strong>人员姓名</strong></font></td>
13 <td align="center" bgcolor="#003399"><font size="2" color="#ffffff"><strong>部门职务</strong></font></td>
14 </tr>
15 </table>
16 </td>
17 </tr>
18 </table>
直接用asp.net webcontrols的add方法,将label添加到html的cell中。
1public class webform2 : system.web.ui.page
2 {
3
4 struct personrole
5 {
6 public string name;
7 public string role;
8 }
9
10 protected system.web.ui.htmlcontrols.htmltable tblcontainer;
11 public string straudititemid = "a899b637-ac47-42eb-9b61-a61c9c880ddc";
12 private void page_load(object sender, system.eventargs e)
13 {
14 // 在此处放置用户代码以初始化页面
15 if(request.querystring["audititemid"] != null)
16 {
17 straudititemid = request.querystring["audititemid"].tostring();
18 }
19
20 getteammember(straudititemid);
21 }
22
23 web 窗体设计器生成的代码#region web 窗体设计器生成的代码
24 override protected void oninit(eventargs e)
25 {
26 //
27 // codegen: 该调用是 asp.net web 窗体设计器所必需的。
28 //
29 initializecomponent();
30 base.oninit(e);
31 }
32
33 /**//// <summary>
34 /// 设计器支持所需的方法 - 不要使用代码编辑器修改
35 /// 此方法的内容。
36 /// </summary>
37 private void initializecomponent()
38 {
39 this.load += new system.eventhandler(this.page_load);
40
41 }
42 #endregion
43
44 private void getteammember(string audititemid)
45 {
46 string strmaster, strteamleader, strpm;
47 arraylist al = getteammembername(audititemid, out strmaster, out strteamleader, out strpm);
48
49 foreach(personrole pr in al)
50 {
51 htmltablecell cell=new htmltablecell();
52 cell.align = "center";
53 label lbl = new label();
54 lbl.text = pr.name;
55 lbl.font.size = 9;
56
57 cell.controls.add(lbl);
58 htmltablerow row=new htmltablerow();
59 row.cells.add(cell);
60
61 htmltablecell cellrole = new htmltablecell();
62 cellrole.align = "center";
63 label lblrole = new label();
64 lblrole.text = pr.role;
65 lblrole.font.size = 9;
66
67 cellrole.controls.add(lblrole);
68 row.cells.add(cellrole);
69
70 tblcontainer.rows.add(row);
71 }
72 }
73
74 private arraylist getteammembername(string audititemid, out string strmastername, out string strteamleader,out string strpm)
75 {
76 arraylist al = new arraylist();
77 strmastername = "无";
78 strteamleader = "无";
79 strpm = "无";
80
81 personrole pr;
82 pr.name = "张三";
83 pr.role = "总经理";
84 al.add(pr);
85
86 pr.name = "李四";
87 pr.role = "副总经理";
88 al.add(pr);
89
90 pr.name = "王五";
91 pr.role = "科员";
92 al.add(pr);
93
94 pr.name = "赵六";
95 pr.role = "科员";
96 al.add(pr);
97
98 return al;
99 }
100 }
在绘制页面的时候,用哪种方式应该是仁者见仁、智者见智。在站点开发中,这3种方式都有典型的应用,特别是第三种,我发现在解决部分页面处理的性能问题中应用的非常有效。况且可以自动化的layout页面控件,个性化处理比datagrid中重写render更加容易。
- · .NET平台下几种SOCKET模型的简要性能供参考
- · 使用 XML 模板 (MSSQL手册)
- · 使用带批注的 XDR 架构创建 XML 视图
- · 在XPath查询中指定轴(转自MSSQL手册)
- · JavaScript极速狂飙:CSS样式表的背景渲染效率
- · javascript应用:实现复选框全选/全不选切换
- · JavaScript极速狂飙:大容量字符型数组的快速检索
- · JavaScript极速狂飙:组合拼接字符串的效率
- · 图片自动缩小的js代码,用以防止图片撑破页面
- · PHP漏洞中的战争
- · automation服务器不能创建对象
- · Oracle数据库的备份及恢复策略研究
- · PHP程序加速探索之脚本执行速度测试
- · PHP中路径问题的解决方案
- · 学以致用 驳“ASP低能论”
- · 另类扩展名同样执行ASP
- · 语言决不是语法的不同之.NET 版本计算表达式的值
- · ASP中实现的类似URLEncode的编码函数及对应解码函数
- · 数据对象扩展成默认组件 PHP开发小组发布PHP5.1.0
- · ASP.NET 揭秘 ASP.NET页面的结构
- · 关于Sql server数据库日志满的快速解决办法
- · PHP+MySQL分页显示示例分析
- · ORACLE SQL性能优化系列(九)
- · ORACLE SQL性能优化系列(七)
- · ORACLE SQL性能优化系列(八)
- · JSP渐进学习教程4
- · ORACLE SQL性能优化系列(三)
- · ORACLE SQL性能优化系列(二)
- · ORACLE SQL性能优化系列(四)
- · ORACLE SQL性能优化系列(五)
- · ORACLE SQL性能优化系列(六)
- · ORACLE SQL性能优化系列(一)
- · JSP渐进学习教程7
- · JSP渐进学习教程6
- · JSP渐进学习教程5
- · JSP渐进学习教程9
- · JSP渐进学习教程8
- · 用多活动结果集优化ADO.NET2.0数据连接
- · PHP 5.0 的变化与PHP 6.0 展望
- · C#中从HTML生成DOM TreeView的代码
- · C#下从HTML文件生成DOM树
- · JSP渐进学习教程1
- · JSP渐进学习教程2
- · C#中的委托与事件[翻译]
- · 2分法-通用存储过程分页(top max模式)版本
- · 怎样获得Sqlserver 2000得实例列表和运行在一个实例上得数据库列表
- · 利用WWF进行ASP.NET程序开发
- · ASPImage组件的实现过程
- · Asp.net(c#)实现多线程断点续传
- · .NET中书写XML的一种简单方法
- · ASP.Net项目出错处理方法汇总
- · php中实现多线程
- · 用ASP实现开关IIS不重启电脑
- · 利用ASP发送和接收XML数据的处理方法
- · XMLHTTP对象应用开发初体验
- · 剖析ASP.NET2.0导航功能之控制地图信息
- · SQL Server 2005上市 竞争者称无新意
- · 利用XMLBean轻轻松松读写XML
- · SQL Server 2005 全新的数据整合服务
- · AMD与微软结盟推出Microsoft SQL Server 2005

