7

真的很奇怪,这个。

我正在使用 anasp: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 会这样渲染它,以及我能做些什么来阻止它。

4

3 回答 3

11

这似乎是 IE9 在渲染大表时的一个已知错误。删除 table def 开始和结束标记之间的空格时,问题已解决,例如。</td><td>

MSDN 讨论 IE 9 渲染

于 2012-08-31T16:56:02.127 回答
3

这是一个已知的 IE9 问题,您可以通过在 HTML 页面中的某处放置以下代码来解决此问题:

$(function() {
    var browser = $.browser;
    if ( browser.msie && browser.version.slice(0,3) == "9.0" ) {
        $('table').each(function(index) {
                var replace = $(this).html().replace(/td>\s+<td/g,'td><td'); 
                $(this).html(replace);
        });
    }
});
于 2012-09-24T20:06:50.763 回答
-2

当发生 Click 事件时,我有一个巨大的表格。仅在 IE9 中发生,在 IE8、IE10、Chrome 等中一切正常。

上述解决方案对我以及其他同类答案都失败了。

我是这样解决的:

我在表格中添加了边框,很明显 HTML 不正确。要么缺少一些 colspan,要么需要的单元格&nbsp;或可能是任何东西。

我还注意到,现在有了表格border=1属性,点击扩展的问题就消失了。

所以我把一个类放在xltable桌子上并放入.xltable td {border:0px solid white;}我的css。

我的代码仍然不是“有效的”,但它可以工作。

于 2014-10-23T18:55:13.280 回答