【发布时间】:2012-08-23 20:00:17
【问题描述】:
真的很奇怪,这个。
我正在使用asp:Repeater 创建一个 HTML 表格,如下所示:
标记:
<asp:Repeater ID="myRpt" runat="server">
<HeaderTemplate>
<table id="myGrd" border="0" style="cursor:pointer;width:100%; background-color:white;" cellpadding="2" cellspacing="0">
<tbody>
</HeaderTemplate>
<ItemTemplate>
<tr onclick="criteria.rowClicked(this);">
<td style="border:solid 1px black;">
<asp:Literal ID="lblName" runat="server"></asp:Literal>
</td>
<td style="border:solid 1px black;width:200px;">
<asp:Literal ID="lblRange" runat="server"></asp:Literal>
</td>
<td style="display:none;" >
<asp:Literal ID="lblMisc" runat="server"></asp:Literal>
</td>
</tr>
</ItemTemplate>
<FooterTemplate>
</tbody> </table>
</FooterTemplate>
</asp:Repeater>
VB:
Public Sub populateGrid(ByVal ds As DataSet)
'ds is just made from a simple select query
myRpt.DataSource = ds
myRpt.DataBind()
End Sub
Private Sub myRpt_ItemDataBound(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles myRpt.ItemDataBound
If e.Item.ItemType = ListItemType.Item Or e.Item.ItemType = ListItemType.AlternatingItem Then
Dim lblName As Literal = e.Item.FindControl("lblName")
Dim lblRange As Literal = e.Item.FindControl("lblRange")
Dim lblMisc As Literal = e.Item.FindControl("lblMisc")
lblName.Text = "<font style='font-size:10pt; font-family:arial;'>" & Trim(e.Item.DataItem("Name")) & "</font>"
lblRange.Text = "<font style='font-size:10pt; font-family:arial;'>" & Trim(e.Item.DataItem("Range")) & "</font>"
lblMisc.Text = "<font style='font-size:10pt; font-family:arial;'>" & Trim(e.Item.DataItem("Miscellaneous")) & "</font>"
End If
End Sub
这在 Firefox 和 Chrome 中显示良好,并且大部分时间在 IE 中显示。然而,有时对于较大的表(50 多行),IE 的行为很奇怪。它似乎添加了一个空白单元格...
...但是 HTML 中没有任何内容 - 我使用开发人员工具进行了检查。不正确的行与正确的行具有相同的标记,但单元格文本除外。更重要的是,如果我删除了错误的行,它上面的行就会开始显示错误。
请有人建议为什么 IE 会这样渲染它,以及我能做些什么来阻止它。
【问题讨论】:
-
看起来这是一个 HTML/CSS/IE 问题,与 ASP 无关。你有没有机会在 JS Fiddle 中复制这个问题? (jsfiddle.net)
-
我已将 HTML 复制到 jsfiddle 中。奇怪的是,它似乎在那里渲染好。
-
只是一个想法 - IE 是否以 Quirks 模式呈现页面?如果在页面上打开开发者工具,菜单栏右侧的浏览器模式和文档模式是什么?
-
浏览器模式:IE9。文档模式:IE9标准
-
由于我没有看到任何 eval() 或任何东西,您实际上是如何将您的值绑定到转发器的?
标签: asp.net vb.net internet-explorer-9 rendering html-table