1

当我进行 jquery ajax 调用以在页面加载时自动填充下拉列表时,下拉控件被包含表切断。我知道如果将表格宽度设置为 100%,它会解决这个问题,但在我的情况下,我不能这样做。此代码在 FF 中运行良好。这几乎就像 IE 不会在 ajax 调用完成后“重新渲染”页面。这是代码——

<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.1/jquery.min.js"></script>
</head>
<body>
<table border="1">
    <tr>
        <td>
            <select>
                <option>Test 1</option>
                <option>Test 2</option>
                <option>Test 3</option>
            </select>
        </td>
    </tr>
    <tr>
        <td>
            <select id="mySelect">              
            </select>
        </td>
    </tr>
</table>

<script type="text/javascript">
var mySelect = $( "#mySelect" );

fillListCombo = function( json )
{
    if ( json )
    {
        mySelect.empty();
        $( json ).each( function( i, obj )
        {
            var option = $( "<option></option>" );
            option.val( obj.id );
            option.text( obj.text );
            option.appendTo( mySelect );
        } );
    }
    else
    {
        mySelect.find( 'option' ).remove().end().append( '<option value="0">(none available)</option>' ).val( '0' );
    }
}

updateListCombo = function()
{
    $.ajax(
    {
        type: "GET", url: "http://localhost/Ajax/ListLookupPage.aspx", dataType: "json", data:
        {
            listkindid: "1", userid: "17"
        },
        timeout: 2000, success: function( opts )
        {
            fillListCombo( opts );
        },
        error: function( xhr, status )
        {
            mySelect.find( 'option' ).remove().end().append( '<option value="0">(none selected)</option>' ).val( '0' );
        }
    } );
};

updateListCombo();
</script>
</body>
</html>

我希望我可以提供一个公共的 Ajax 页面,以便可以将其复制并粘贴到文本编辑器中以供您自己尝试,但我没有。

它在 Firefox 中的显示方式: 它在 IE7/8 中的显示方式: 关于如何在 ajax 回调完成后强制 IE 7/8 正确呈现的任何想法?
替代文字

替代文字

谢谢。

4

1 回答 1

3

有点hack,但似乎如果您更改选择的不需要的css属性,它将强制更新。

$('#mySelect').css({margin: '0'}).append('<option value="0">(none available)</option>');

(从你的例子中截断,但原则应该是一样的。)

我仅在 XP 上使用 ie7 对此进行了测试。

于 2009-06-04T16:48:17.710 回答