我有一个内容页面,其中包含以下内容...
- UpdatePanel1 - 包含错误显示 Div
包含两个按钮的更新触发器
- UpdatePanel2 - 包含带有 asp:button 的进程 1
- updatePanel3 - 包含带有 asp:button 的进程 2
- JavaScript 根据用户正在执行的进程向用户显示弹出确认 Jquery Messagebox。
UpdatePanel 2 或 3 根据用户从菜单选项中的选择而变得可见。
当我单击按钮时,消息框会弹出,并且使用消息框响应中的 __doPostback 正确处理页面,并且页面会进行完整的回发。
我宁愿页面进行部分回发及其内容,并在出现错误时显示错误显示 Div。任何援助将不胜感激。
按钮没什么特别的
<asp:Button ID="ResetSomething" runat="server" Text="ResetSomething" Width="275px" />
这是内容页脚本块
<script type="text/javascript" language="javascript">
<!--
function pageLoad() {
setform();
};
function setform() {
var reset1_button = $('input[id*=ResetSomething]');
var reset2_button = $('input[id*=ResetSomethingElse]');
reset1_button.click(function() {
var element = $(this);
$.prompt('Message1', { show: 'slideDown', buttons: { Ok: true, Cancel: false },
submit: function(v, m, f) { submit_reset_callback(v, m, element); }
});
return (false);
});
var submit_reset_callback = function(result, messages, element) {
if (result) { __doPostBack("ResetSomething");}
return (false);
};
reset2_button.click(function() {
var element = $(this);
$.prompt('Message2', { show: 'slideDown', buttons: { Ok: true, Cancel: false },
submit: function(v, m, f) { submit_update_callback(v, m, element); }
});
return (false);
});
var submit_update_callback = function(result, messages, element) {
if (result) { __doPostBack("ResetSomethingElse"); }
return (false);
};
};
-->
</script>
这是 OnInit 背后的代码:
protected override void OnInit(EventArgs e)
{
base.OnInit(e);
this.PreLoad += (sender, args) =>
{
this.ClientScript.GetPostBackEventReference(this, "arg");
if (!IsPostBack) { return; }
string __targetaction = this.Request["__EVENTTARGET"];
string __args = this.Request["__EVENTARGUMENT"];
if (string.IsNullOrEmpty(__args)) return;
if (__targetaction == "ResetSomething")
{
ResetSomething();
}
if (__targetaction == "ResetSomethingElse")
{
ResetSomethingElse();
}
this.upnlNotifications.Update();
};
}