欢迎光临
我们一直在努力

ASP.NET中用哪种方式表格化数据-.NET教程,Asp.Net开发

建站超值云服务器,限时71元/月

在开发asp.net站点项目中,经常用表格化的方式显示数据。最常用的可能就是datagrid绑定dataset数据的方式。在做过的软件项目中,有3种表格化数据的典型处理方式。
    1、datagrid绑定数据源。这种方式大家用的最多,但是datagrid与ado.net完美的绑定方式,还是让人不爽。清一色的datagrid风格很难适应不同项目的特殊风格,而且在datagrid上做出的个性化处理也会非常的麻烦。
    2、用xml(数据)+xsl(样式单)。大家能理解,dataset绑定到datagrid的实现机理不过如此。如图所示,实现这样的一个表格,开发人员可以尽情的设计xsl的风格样式。
ASP.NET中用哪种方式表格化数据-.NET教程,Asp.Net开发

    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更加容易。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » ASP.NET中用哪种方式表格化数据-.NET教程,Asp.Net开发
分享到: 更多 (0)