ASP.NET中用哪种方式表格化数据

asp.net|数据

   在开发ASP.NET站点项目中,经常用表格化的方式显示数据。最常用的可能就是DataGrid绑定DataSet数据的方式。在做过的软件项目中,有3种表格化数据的典型处理方式。

   1、DataGrid绑定数据源。这种方式大家用的最多,但是DataGrid与ADO.NET完美的绑定方式,还是让人不爽。清一色的DataGrid风格很难适应不同项目的特殊风格,而且在DataGrid上做出的个性化处理也会非常的麻烦。

   2、用XML(数据)+XSL(样式单)。大家能理解,DataSet绑定到DataGrid的实现机理不过如此。如图所示,实现这样的一个表格,开发人员可以尽情的设计XSL的风格样式。
  
  
  3、直接将数据绘制到HTML。这个方式有些土,但有些时候却非常有效,先看实现的代码。下述代码是实现上图所示的表格。

   1<table style="WIDTH: 100%; BORDER-COLLAPSE: collapse; HEIGHT: 10px">
   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更加容易。

时间: 2024-10-19 02:35:33

ASP.NET中用哪种方式表格化数据的相关文章

开发 ASP.NET 站点中的三种表格化数据方法

asp.net|数据|站点 在开发ASP.NET站点项目中,经常用表格化的方式显示数据.最常用的可能就是DataGrid绑定DataSet数据的方式.在做过的软件项目中,有3种表格化数据的典型处理方式. 1.DataGrid绑定数据源.这种方式大家用的最多,但是DataGrid与ADO.NET完美的绑定方式,还是让人不爽.清一色的DataGrid风格很难适应不同项目的特殊风格,而且在DataGrid上做出的个性化处理也会非常的麻烦. 2.用XML(数据)+XSL(样式单).大家能理解,DataS

ASP.NET中的三种表格化数据方法

asp.net|数据     在开发ASP.NET站点项目中,经常用表格化的方式显示数据.最常用的可能就是DataGrid绑定DataSet数据的方式.在做过的软件项目中,有3种表格化数据的典型处理方式. 1.DataGrid绑定数据源.这种方式大家用的最多,但是DataGrid与ADO.NET完美的绑定方式,还是让人不爽.清一色的DataGrid风格很难适应不同项目的特殊风格,而且在DataGrid上做出的个性化处理也会非常的麻烦. 2.用XML(数据)+XSL(样式单).大家能理解,Data

ASP.NET中表格化数据的方式

在开发ASP.NET站点项目中,经常用表格化的方式显示数据.最常用的可能就是DataGrid绑定DataSet数据的方式.在做过的软件项目中,有3种表格化数据的典型处理方式. 1.DataGrid绑定数据源.这种方式大家用的最多,但是DataGrid与ADO.NET完美的绑定方式,还是让人不爽.清一色的DataGrid风格很难适应不同项目的特殊风格,而且在DataGrid上做出的个性化处理也会非常的麻烦. 2.用XML(数据)+XSL(样式单).大家能理解,DataSet绑定到DataGrid的

JS中用三种方式实现导航菜单中的二级下拉菜单_javascript技巧

我们在淘宝.搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如下面这张图片.那么如何实现导航菜单栏中的二级下拉菜单?下面小编给大家分享实现思路. 但是如何实现类似的图片呢?实际上,我们有至少三种方式来实现,下面,我附上代码供大家参考. 1.仅使用html和css <meta charset="UTF-8"> <title>Document</title> <style> *{margin:0;padding: 0;list-style

js脚本-ASP.NET中加入JS 改变表格中数据

问题描述 ASP.NET中加入JS 改变表格中数据 <%@ Page Language=""C#"" AutoEventWireup=""true"" CodeBehind=""index.aspx.cs"" Inherits=""webgf.GF"" %> <!DOCTYPE html PUBLIC ""-/

javascript解析json数据的3种方式_javascript技巧

3种方式解析json数据 复制代码 代码如下: var obj=eval("("+traItem.rel+")"); //性能不好 var obj = (new Function("return " + traItem.rel))(); var obj = JSON.parse(traItem.rel); //这个要求的格式比较严格

WEB页面中的结构化数据表示的方式:表格

组织数据和信息是一个不可疏忽的能力.组织内容和文字的方式(一般以copy的形式)会在用户怎样接收内容上有直接的影响.网页设计需要找到一个方法组织内容以使其便于读者扫描和接收.其中一个简洁的方法就是运用数据表格.表格提供结构化的方式来展示大量的信息. 从web发展开始时起,表格就已被使用.表格的结构至今没变,也不会变,这才让它不至于不是表格.结构虽然没变动,不过样式风格却已经有了长远的发展:现在的表格仍然与早期的表格一样有可读性. 数据表格的一般运用 表格轻易就能用简洁和易读的方式来组织数据.它们

ASP中存储过程调用的两种方式及比较

比较|存储过程|存储过程 beerfroth(原作) 本人用sql server 和asp写了一个简单的留言本,在不断的尝试中发现,分页显示留言的时候,不同的执行方式,时间上的一些差别. 下面通过对比来看看几种方式的用时对比. 一,使用存储过程分页,这种情况又分为两种方式: 第一种,使用command对象,如下: Set Cmd=server.CreateObject("Adodb.Command")Cmd.ActiveConnection=connCmd.CommandText=&q

ASP中存储过程调用的两种方式,以及不采用存储过程的方式比较

比较|存储过程 本人用sql server 和asp写了一个简单的留言本,在不断的尝试中发现,分页显示留言的时候,不同的执行方式,时间上的一些差别. 下面通过对比来看看几种方式的用时对比. 一,使用存储过程分页,这种情况又分为两种方式: 第一种,使用command对象,如下: Set Cmd=server.CreateObject("Adodb.Command")Cmd.ActiveConnection=connCmd.CommandText="ycuu_gb_getmsg&