如何在ASP.NET中最好地填充HTML表?
发布时间:2020-12-16 03:27:39 所属栏目:asp.Net 来源:网络整理
导读:这就是我所拥有的.有用.但是,有更简单或更好的方法吗? ASPX页面…… asp:Repeater ID="RepeaterBooks" runat="server" HeaderTemplate table class="report" tr thPublished/th thTitle/th thAuthor/th thPrice/th /tr /HeaderTemplate ItemTemplate tr tda
这就是我所拥有的.有用.但是,有更简单或更好的方法吗?
ASPX页面…… <asp:Repeater ID="RepeaterBooks" runat="server"> <HeaderTemplate> <table class="report"> <tr> <th>Published</th> <th>Title</th> <th>Author</th> <th>Price</th> </tr> </HeaderTemplate> <ItemTemplate> <tr> <td><asp:Literal ID="LiteralPublished" runat="server" /></td> <td><asp:Literal ID="LiteralTitle" runat="server" /></td> <td><asp:Literal ID="LiteralAuthor" runat="server" /></td> <td><asp:Literal ID="LiteralPrice" runat="server" /></td> </tr> </ItemTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> ASPX.VB代码背后…… Protected Sub Page_Load( ByVal sender As Object,ByVal e As System.EventArgs) Handles Me.Load Dim db As New BookstoreDataContext RepeaterBooks.DataSource = From b In db.Books _ Order By b.Published _ Select b RepeaterBooks.DataBind() End Sub Sub RepeaterBooks_ItemDataBound( ByVal sender As Object,ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles RepeaterBooks.ItemDataBound If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem Then Dim b As Book = DirectCast(e.Item.DataItem,Book) DirectCast(e.Item.FindControl("LiteralPublished"),Literal).Text = "<nobr>" + b.Published.ToShortDateString + "</nobr>" DirectCast(e.Item.FindControl("LiteralTitle"),Literal).Text = "<nobr>" + TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Title)) + "</nobr>" DirectCast(e.Item.FindControl("LiteralAuthor"),Literal).Text = "<nobr>" + TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Author)) + "</nobr>" DirectCast(e.Item.FindControl("LiteralPrice"),Literal).Text = "<nobr>" + Format(b.Price,"c") + "</nobr>" End If End Sub Function TryNbsp(ByVal s As String) As String If s = "" Then Return " " Else Return s End If End Function 解决方法
@Geoff
那种Eval语句实际上是在2.0中添加的,但是如果性能很重要,应避免使用Eval,因为它使用了Reflection. 转发器是一种非常好的方法,尽管在代码中生成表可能更快: ASPX页面: <table class="report" id="bookTable" runat="server"> <tr> <th>Published</th> <th>Title</th> <th>Author</th> <th>Price</th> </tr> </table> 代码背后: Protected Sub Page_Load( ByVal sender As Object,ByVal e As System.EventArgs) Handles Me.Load If Not Page.IsPostback Then BuildTable() End If End Sub Private Sub BuildTable() Dim db As New BookstoreDataContext Dim bookCollection = from b in db.Books _ Order By b.Published _ Select b Dim row As HtmlTableRow Dim cell As HtmlTableCell For Each book As Books In bookCollection row = New HtmlTableRow() cell = New HtmlTableCell With { .InnerText = b.Published.ToShortDateString } row.Controls.Add(cell) cell = New HtmlTableCell With { .InnerText = TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Title)) } row.Controls.Add(cell) cell = New HtmlTableCell With { .InnerText = TryNbsp(HttpContext.Current.Server.HtmlEncode(b.Author)) row.Controls.Add(cell) cell = New HtmlTableCell With { .InnerText = Format(b.Price,"c") } row.Controls.Add(cell) bookTable.Controls.Add(row) Next 我想这取决于速度对你的重要程度.为简单起见,我想我会选择Repeater. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc-3 – 如何从ModelMetadata检索GroupName数据注
- asp.net – 在更改密码时从所有浏览器注销用户
- asp.net-mvc – ASP.NET MVC 3绑定确保表单值优先
- asp.net – 如何获取网站根URL?
- asp.net – 调试:当类型IS标记为可序列化时,如何调试“类型
- 使用Asp.net的Amazon Book Search API
- .net – 什么可以解释托管堆上超过5,000,000个System.WeakR
- ASP.NET MVC – jquery datepicker
- 使用log4net和ASP.NET跟踪会话变量
- ASP.NET MVC验证属性和Jquery
推荐文章
站长推荐
热点阅读