如果在下拉列表中选择索引后,如何避免页面刷新?

Muh*_*eel 6 vb.net asp.net ajaxcontroltoolkit visual-studio-2010 c#-4.0

我正在使用更新面板和ASP下拉.当我从下拉列表中选择任何值时,我会从依赖于此选定值的数据库中加载一些数据.但是,每当此选择更改时,页面都将刷新.如何避免此页面刷新?我也尝试过AsyncPostBackTrigger,但仍然会出现此问题.

<asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server" EnablePartialRendering="false">
   </asp:ToolkitScriptManager>
        <asp:UpdatePanel ID="OuterUpdatePanel" runat="server">
            <ContentTemplate>
                <asp:DropDownList ID="ddList" CssClass="dropdown" Style="width: 200px !important;"
                 runat="server" AutoPostBack="true" OnSelectedIndexChanged="ddList_SelectedIndexChanged">
                </asp:DropDownList>
            </ContentTemplate>
        </asp:UpdatePanel>
Run Code Online (Sandbox Code Playgroud)

Ash*_*ngh 5

如果您希望下拉列表在不刷新页面的情况下触发Ajax调用而不删除,请添加此项 AutoPostBack="true"

<Triggers> 
<asp:AsyncPostBackTrigger ControlID="ddList" EventName="SelectedIndexChanged" /> 
</Triggers> 
Run Code Online (Sandbox Code Playgroud)


Jai*_*res 5

我相信,你问题的症结在于:

"当我从下拉列表中选择任何值时,我会从依赖于此选定值的数据库中加载一些数据,每当选择更改页面刷新时,我都会遇到问题."

有很多方法可以实现这一目标,但可能需要进行一些重组才能产生预期的效果.一个相对简单的方法是:

(1)重新组织您的页面如下:

<asp:DropDownList ID="ddList" CssClass="dropdown" Style="width: 200px !important;" runat="server" AutoPostBack="false">
</asp:DropDownList>

<asp:UpdatePanel ID="OuterUpdatePanel" runat="server">
        <ContentTemplate>
        <!-- Content goes here -->
        </ContentTemplate>
</asp:UpdatePanel>
Run Code Online (Sandbox Code Playgroud)

(2)添加脚本如下:

<script type="text/javascript">
function handleDDLChange() {
  __doPostBack($('div[id$="OuterUpdatePanel"]').attr('id'), 'ddlList_Changed_Or_Anything_Else_You_Might_Want_To_Key_Off_Of');
}

$('input[id$="ddlList"]').change( handleDDLChange );
</script>
Run Code Online (Sandbox Code Playgroud)

这是一种更"老派"的方法,但它应该可以解决您的问题.

编辑:以下说明了一个"非jQuery"方法,上面的想法更加充实:

ASCX:

<asp:ScriptManager runat="server" />

<asp:DropDownList ID="ddlList" runat="server" onchange="handleDDLChange()">
    <asp:ListItem Text="text1" />
    <asp:ListItem Text="text2" />
</asp:DropDownList>

<script type="text/javascript">
    function handleDDLChange() {
        __doPostBack("<%= ddlList.ClientID %>", "ddlList_Changed_Or_Anything_Else_You_Might_Want_To_Key_Off_Of");
    }
</script>

 <asp:UpdatePanel ID="UpdatePanel1" runat="server">
   <ContentTemplate>
       <asp:Literal ID="litTest" runat="server" />
   </ContentTemplate>
</asp:UpdatePanel>
Run Code Online (Sandbox Code Playgroud)

代码隐藏:

protected void Page_Load(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {
        litTest.Text = "No postback";
    }
    else if (Request["__EVENTARGUMENT"] == "ddlList_Changed_Or_Anything_Else_You_Might_Want_To_Key_Off_Of")
    {
        litTest.Text = string.Format("Dropdown changed: {0}", ddlList.Text);
    }
    else
    {
        litTest.Text = "Postback for some other reason... :(";
    }
}
Run Code Online (Sandbox Code Playgroud)