关于ASP.NET:ASP.NET-是否可以从服务器代码触发回发?

关于ASP.NET:ASP.NET-是否可以从服务器代码触发回发?

ASP.NET - Is it possible to trigger a postback from server code?

是否可以以编程方式触发ASP.NET中服务器代码的回发? 我知道可以执行Response.Redirect或Server.Transfer重定向到页面,但是有没有办法在服务器代码中触发回发到同一页面(即,无需使用JavaScript技巧来提交表单)?


从客户端启动Asp.net回发(通常是表单提交)。我不确定您要达到什么目标。一些服务器端页面生命周期事件已经执行,您想要做的是再次引发先前的事件处理程序。


回发是由FORM提交引起的。您需要从客户端启动它们。


如果您希望从服务器启动通信而不是轮询,请查看Microsoft的SignalR。最简单的上下文是SignalR作为其示例代码的一部分,它是一个聊天应用程序。您将能够从背后的代码中发起消息,并在页面上以javascript事件的形式接收消息。

要发送的服务器代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
using System;
using System.Web;
using Microsoft.AspNet.SignalR;
namespace SignalRChat
{
    public class ChatHub : Hub
    {
        public void Send(string name, string message)
        {
            // Call the broadcastMessage method to update clients.
            Clients.All.broadcastMessage(name, message);
        }
    }
}

捕获服务器消息的客户端代码是'chat.client.broadcastMessage'的替代:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
<script type="text/javascript">
        $(function () {
            // Declare a proxy to reference the hub.
            var chat = $.connection.chatHub;
            // Create a function that the hub can call to broadcast messages.
            chat.client.broadcastMessage = function (name, message) {
                // Html encode display name and message.
                var encodedName = $('').text(name).html();
                var encodedMsg = $('').text(message).html();
                // Add the message to the page.
                $('#discussion').append('
<li>
' + encodedName
                    + ':' + encodedMsg + '
</li>
');
            };
            // Get the user name and store it to prepend to messages.
            $('#displayname').val(prompt('Enter your name:', ''));
            // Set initial focus to message input box.  
            $('#message').focus();
            // Start the connection.
            $.connection.hub.start().done(function () {
                $('#sendmessage').click(function () {
                    // Call the Send method on the hub.
                    chat.server.send($('#displayname').val(), $('#message').val());
                    // Clear text box and reset focus for next comment.
                    $('#message').val('').focus();
                });
            });
        });

您可以通过Ajax请求来完成。您必须让页面轮询服务器。服务器没有任何方式无需请求即可将信息推送到浏览器。但是,让某些Javascript在后台运行并每5秒(或更长,取决于您的需求)对服务器进行一次轮询可能是最好的解决方案。

附加

如果采用这种方式,则可以根据是否应执行回发,让服务器仅发送"是"或"否",甚至仅发送0或1。根据您的需求,没有很多理由真正使用AJAX的XML部分。只需运行一个简单的异步请求(可能带有几个querystring变量),然后返回一个简单的单词,甚至一个数字作为响应即可。这样,您就可以保留不需要的javascript来创建和解析XML。


对于使用较新版本.NET的用户,必须使用Page.ClientScript.GetPostBackEventReference,因为'this.GetPostBackEventReference(...)'已过时。也可能是Page.ClientScript.RegisterStartupScript(...


推荐阅读