几个小时以来,我一直在摸索这个问题,这个问题似乎很有趣。我似乎错过了__doPostBack
我应该控制的事件,但事实并非如此。有人建议添加:
ClientScript.GetPostBackEventReference(this, string.Empty);
然而,虽然它确实创建了我正在寻找的函数定义,但无论我做什么,页面都会在回发事件中重新加载。正如一些人提到的:
这是因为控件 ID 不匹配/未找到。
考虑到 1) 回发功能不会在没有被蛮力强制的情况下呈现,我显然做错了 2) 即使在蛮力强制进入时,回发也找不到合适的设置。以下是代码片段:
类定义
[ParseChildren(true)]
[PersistChildren(true)]
[ToolboxData("<{0}:Accordion runat=server></{0}:Accordion>")]
public class Accordion : DataBoundControl, IPostBackEventHandler
活动
public event JQUI_Event ItemClick;
单击处理程序、RaisePostBackEvent 和附加 __doPostBack 的 OnLoad
public void RaisePostBackEvent(string eventArgument)
{
ItemClick(null, null);
}
protected override void OnLoad(EventArgs e)
{
Page.ClientScript.GetPostBackEventReference(this, string.Empty);
base.OnLoad(e);
}
protected virtual void OnClick(EventArgs e)
{
if (ItemClick != null)
{
ItemClick(null, null);
}
}
最后生成回发的代码:
if (ItemClick != null)
{
outPut += "<script> $(function() { $('#" + ClientID + "').find('div').on('click', function() { __doPostBack('" + UniqueID + "', '') }); }); </script>";
}
writer.Write(outPut);
如果您需要更多代码,请告诉我。我不想只是抛出一长页代码,然后告诉人们弄清楚。
编辑:
好的,调用了 RaisePostBackEvent(string eventArgument)。但是,我遇到的问题是页面仍然决定重新加载。我已经测试以确保它在正确的控件中调用正确的函数(不仅仅是因为它是回发)。有没有办法将其限制为部分回发而不是完整回发?