0

我正在尝试添加一个 JavaScript 函数,以将 ListBox 中的所有选定项目显示为页面上标签中的连接字符串。这是必需的,因为 AutoPostBack="true" 将导致 ListBox 一直滚动回第一个选定项目。

所以这段代码有效:

 <script type="text/javascript">
    function Updatelist() { 
        var sel = document.getElementById('<%=lstbxStuff.ClientID%>'); 
        var lbl = document.getElementById('ctl00_cph_lblSelectedStuff');
        var listLength = sel.options.length; 
        var textForListbox = "";
        var list2length = 0;
        for (var i = 0; i < listLength; i++) { 
            if (sel.options[i].selected) { 
               if(list2length == 0) {
                    textForListbox = sel.options[i].text; 
                } else {
                    textForListbox = textForListbox + ", " + sel.options[i].text; 
                }
                list2length++; 
            } 
        } 
        lbl.innerText=textForListbox;

        return textForListbox;
    } 
</script>

不幸的是,我仍然需要 SelectedIndexChanged 委托背后的代码。有没有办法在不做 PostBack 的情况下同时使用这两种方法?当我设置 AutoPostBack="false" 时,似乎永远无法联系到我的代表。

4

2 回答 2

0

如果这不是您想要的行为,我认为 AutoPostBack 不是您想要的方式。当 ASP.Net 进行完整的回发时,它与“传统”HTML 表单发布相同,将表单的全部内容发送回服务器并等待响应(这恰好是同一页面,因为Asp.Net 回应)。因此,为什么列表框中的位置会丢失 - 这是您要返回的全新列表框。

您是否将 ASP.Net Ajax (UpdatePanels) 视为一种可能的选择?这与回发的行为相同,因为它将数据发送回服务器并调用您的方法,但只回发页面的一部分。

于 2010-10-25T22:06:22.077 回答
0

如果你想调用服务器端的代理,那么你必须做一个 PostBack。

服务器上需要运行的代码是什么?您应该能够在 JavaScript 中完成所有工作,然后在选择所有列表项后使用不同的触发器(不是 selectedIndexChange)来运行服务器端代码。

您是否还看到,Ajax UpdatePanel 和维护ScrollPositionOnPostBack="true" 以便页面在回发后保持其滚动位置。但是,这只会影响页面滚动条而不是选择框。

于 2010-10-25T22:06:32.980 回答