在服务器站点 ASP.NET 中创建对话框确认

问题描述

我想在 ASP.NET 中创建一个对话框确认。

我正在使用此代码进行操作:

protected void Button1_Click(object sender,EventArgs e)
{
    ClientScriptManager CSM = Page.ClientScript;
    
    string strconfirm = "<script>if(!window.confirm('Are you sure?')){window.location.href='Default.aspx'}</script>";
    CSM.RegisterClientScriptBlock(this.GetType(),"Confirm",strconfirm,false);
        
    if (the condition to yes clicked)
    {
        // do something ....
    }
    else 
    {
        // do something else ....
    }
}

在这种情况下如何获得是/否条件?

感谢阅读我的帖子

解决方法

你不能这样做。您背后的代码永远不会与用户交互。您背后的代码仅与网页交互,并且仅在页面往返时这样做。

在回帖之前?你有这个设置:

enter image description here

你没有这个:

enter image description here

而你也没有这个:

enter image description here

因此,当用户单击按钮时 - 这会发生在客户端。页面 - 整个网页被发送到服务器 - 然后你的代码与网页交互 - 而不是用户!!!

因此,您单击一个按钮 -(浏览器)。页面 THEN 开始所有重要的往返。像这样:

enter image description here

页面传送到服务器,

您现在拥有了:

enter image description here

现在和那时你背后的代码会运行。完成后,您背后的代码必须完成,否则页面会停留在服务器端。完成后,整个页面都会返回浏览器。然后页面重新显示,然后任何js代码都可以运行。

那么什么时候完成?您的页面将返回到浏览器,如下所示:

enter image description here

并且只有在页面完成该行程后,浏览器才能显示您背后的代码更改的内容。因此,您背后的代码永远不会与用户交互,但实际上只能与网页交互,并且只能在网页在服务器上启动的短时间内进行。

那么,您如何弹出对话框并获得是/否答案?好吧,您需要运行对话框并启动客户端。根据用户点击确定或取消,您可以然后运行代码存根。

所以你可以说有这样的代码:

ClientScriptManager CSM = Page.ClientScript;

    string strconfirm = "<script>if(!window.confirm('Are you sure?')){window.location.href='Default.aspx'}</script>";
    CSM.RegisterClientScriptBlock(this.GetType(),"Confirm",strconfirm,false);

 Function OkCode - runs on user click or seleciton.


 Function Cancel Code - runs on user click of cancel button.

因此,您需要 3 个代码存根。一个注入将弹出对话框的脚本。然后该脚本/对话框中的确定或取消按钮可以再次启动服务器端代码。这当然需要往返(就像所有服务器端按钮事件代码一样)。

有一些捷径。假设我有一个标准的 asp.net 按钮,我想要一个确认对话框?好吧,你可以这样做:

        <asp:Button ID="Button1" runat="server" Text="Delete"
            OnClientClick="return confirm('Delete record');"/>

以上有效,因为 js 中的 confrim 返回 true 或 false,这将阻止按钮代码(服务器端的代码)运行。

您当然可以有一个从代码背后调用的脚本。请记住,您的注册脚本必须是您做的最后一件事,并在它返回到客户端之前注入该页面。页面显示,然后您添加的脚本然后运行!

你可以说然后在你的表单上有两个按钮 - 隐藏它们。然后有一个 js 对话框,根据您传递的内容单击任一按钮。

所以,假设我们构建了那个函数。我们将问题/文本传递给它,然后说出两个按钮(一个用于确定单击,一个用于取消单击)。您可以将这些按钮的样式设置为 display:none。如果/那么该对话框的结果,这仍然不会为您提供服务器端。因此,在几乎所有情况下,您都必须将代码分解为 3 个独立的部分。

触发对话的部分。

以及根据用户所做的选择在存根后面运行代码的两个按钮。换句话说,通过脚本添加对话框仍然需要您在后面运行两个单独的代码存根(一个用于确定,另一个用于取消)。您根本无法弹出对话服务器端并等待。这将导致网页在上述往返概念中卡在服务器上。往返对话必须全神贯注在您的脑海中 - 如果没有往返如何工作的模型,那么您的设计假设就会出错 - 因此您的问题实际上是不可能实现的。

您可以创建一个通用对话框,将代码中的文本与您的注册脚本想法一起设置。但是它运行的按钮选择和代码也必须在该注册脚本中设置,并且您仍然需要两个单独的存根代码(一个用于取消,一个用于确定)。因此,可以设置一些不需要在每个页面中包含特殊代码的内容,但是您需要构建一个 js 函数例程,并且必须为其提供两个代码存根的名称,然后js 例程可以发送 __DoPostBack 传递所做的选择。

但同样,请注意您如何需要单独的例程,因为该网页位于用户桌面上,并且您背后的代码不是在等待对话,而是在等待整个页面回传。

所以请记住,后面的代码不会与用户交互——它只与网页交互,并且只在短程往返期间这样做,实际上只在网页在服务器上启动的时候这样做,然后您的代码运行然后完成。然后网页开始返回客户端的旅程 - 页面重新加载,显示您所做的更改,然后该页面中的 js 再次开始运行。