How can I get an UpdatePanel to intercept a CompositeControl's DropDownList

后端 未结 3 1523
花落未央
花落未央 2021-02-11 10:05

I have a CompositeControl that contains a DropDownList.

I have set the AutoPostBack property of the DropDownList to true.

On the page, I have:

&l         


        
相关标签:
3条回答
  • 2021-02-11 10:45

    I had repeating child controls (textbox and labels) in a ListView, inside an UpdatePanel.

    Changing the textbox would cause a full (synch) postback.

    I added the PAGE element (the first line in the .aspx page) : ClientIDMode="AutoID"

    This fixed the problem for me, and now only the UpdatePanel refreshes - as desired.

    0 讨论(0)
  • 2021-02-11 10:51

    Ok so this may not be the best answer, but I think the problem you're having it that the UpdatePanel just can't see the child control's event. Good news is, it's easy to fix. Say you have a control (CatchMyEvent, which by the way is a crazy clever name) and it has a DropDownList on it. Now you want the parent page to see the SelectedIndexChanged event fire on that list and update a label to match the SelectedItem.Text. As it is, the parent can't really do that. So let's change that:

    public partial class CatchMyEvent : System.Web.UI.UserControl
    {
        public delegate void ChangedIndex(object sender, EventArgs e);
        public event ChangedIndex SelectedIndexChanged;
    
        protected override void OnInit(EventArgs e)
        {
            base.OnInit(e);
            dropDownListThrow.SelectedIndexChanged += new EventHandler(dropDownListThrow_SelectedIndexChanged);
            labelOutput.Text = "no";
        }
    
        public void dropDownListThrow_SelectedIndexChanged(object sender, EventArgs e)
        {
            labelOutput.Text = ((DropDownList)sender).SelectedItem.Text;
            if(SelectedIndexChanged != null)
            {
                SelectedIndexChanged(sender, e);
            }
        }
    }
    

    Basically all I did is have the control capture the DropDownList's SelectedIndexChanged event and fired it so that any parent page or control could see it. Essentially all I've done is passed it on. Now on the parent page, it's really easy to capture.

    You just need to add an UpdatePanel with a trigger that holds:

    <asp:AsyncPostBackTrigger ControlID="catchMyEventMain" EventName="SelectedIndexChanged" />
    

    ...and of course add this to the code behind for the parent page:

    protected override void OnInit(EventArgs e)
    {
        base.OnInit(e);
        catchMyEventMain.SelectedIndexChanged += dropDownListThrow_SelectedIndexChanged;
    }
    
    public void dropDownListThrow_SelectedIndexChanged(object sender, EventArgs e)
    {        
        labelSelectedValue.Text = ((DropDownList)sender).SelectedItem.Text;
    }
    

    Where the label is the before mentioned label. And then let the magic happen.

    Also two notes:

    1) Don't be an idiot like I was when testing this and forget to set the AutoPostBack property on the DropDownList to true.

    2) Make sure the label is in the UpdatePanel's ContentTemplate.

    Hope this helps.

    0 讨论(0)
  • 2021-02-11 11:00

    I made the following at the end of the BuildControlHierarchy:

            ...
            if (DesignMode || Page == null) return;
    
            var sm = ScriptManager.GetCurrent(Page);
            if (sm == null)
            {
                throw new MissingFieldException("The ScriptManager is needed on the page!");
            }
            sm.RegisterAsyncPostBackControl(<control which initiates async postback>);
    
    0 讨论(0)
提交回复
热议问题