簡體   English   中英

Ajax CollapsiblePanelExtender在回發時保持狀態

[英]Ajax CollapsiblePanelExtender Keep state on Postback

我有一個gridview。 里面有一個包含按鈕的CollapsiblePanelExtender。 當我按下按鈕時,這會導致回發並且CollapsiblePanelExtender關閉。 我正在嘗試撰寫一種解決方案,以使CollapsiblePanelExtender在發回郵件后保持打開狀態。 到目前為止,這是我嘗試過的:

function pageLoad(sender, args) {
   var objExtender;                
   var retval="";               

   if (document.getElementById(GridView1)) {
      retval = document.getElementById(GridView1);
   }
   var CollapsiblePanelExtender1 = retval.getElementsByTagName("CollapsiblePanelExtender1");

   if(CollapsiblePanelExtender1.get_Collapsed()) {
      CollapsiblePanelExtender1.set_Collapsed(true);
   }
   else {
      CollapsiblePanelExtender1.set_Collapsed(false);
   }
}

基本上,CollapsiblePanelExtender在回發期間保持其狀態。 但是在回發期間,我想您要執行數據綁定(我想您已經這樣做了)。 在數據綁定期間,將重新創建所有控件,這就是為什么它們會松動其內部狀態的原因。

為了解決您的問題,我建議您在執行數據綁定之前先保存CollapsiblePanelExtender的狀態,然后再恢復該狀態。 這可以在服務器端完成。 如果啟用了動畫,這也將有助於避免UI閃爍。

因此,要獲取CollapsiblePanelExtender的狀態,您只需記住它的客戶端狀態值即可。 然后,您將能夠恢復該值。 例如,以下代碼可用於在服務器端擴展/折疊CollapsiblePanelExtender:

// To collapse panel.
this.CollapsiblePanelExtender1.ClientState = "true";

// To Expand panel.
this.CollapsiblePanelExtender1.ClientState = "false";

如果您仍然想在客戶端折疊/展開CollapsiblePanelExtender,則需要以下代碼:

Sys.Application.add_load(function() {
    var extender = $find('<%= this.CollapsiblePanelExtender1.ClientID  %>');

    extender.expandPanel();

    extender.collapsePanel();
});

編輯這無濟於事,因為您嘗試在點擊處理程序中還原狀態。 當您調用網格視圖控件的databind時,不會立即重新創建行。 因此,如果要設置(還原)可折疊擴展器控件的狀態,最好在網格的RowCreated事件處理程序中進行。

例如,您可以使用類似於以下代碼:

    protected void GridView_OnRowCreated(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow && SomeValueToIdentifyThatThisPanelShouldBeExpanded)
        {
            CollapsiblePanelExtender extender =
                e.Row.FindControl("CollapsiblePanelExtender1") as CollapsiblePanelExtender;
            extender.ClientState = "false";
        }
    }

我實際上在我的博客上使用了這些控件,因為asp.net允許我通過中繼器控件使用可折疊面板進行拖放。

技巧是在打開面板時在內容中添加ajax。 您可以輕松地在內容中進行jQuery,以從Web服務中插入頁面或Ajax。

這是帶有可折疊內容的可折疊面板的示例。 面板由Web服務加載。 單擊以展開面板。

http://gosylvester.com/blog.aspx?id=39

您是否嘗試過在可折疊面板擴展器上設置SuppressPostBack =“ True”

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM