我试图获得长时间运行操作的状态进度。它在FF :),Opera和IE中运行良好:?,但在Chrome中?!它失败了:它永远不会进入Generic Handler中的ProcessRequest。拜托,你能告诉我做错了什么吗?
的Default.aspx:
<%@ Page Title="Home Page" Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true"
CodeBehind="Default.aspx.cs" Inherits="AspNetProgressBar._Default" %>
<asp:Content ID="HeaderContent" runat="server" ContentPlaceHolderID="HeadContent">
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"></script>
</asp:Content>
<asp:Content ID="BodyContent" runat="server" ContentPlaceHolderID="MainContent">
<asp:Button runat="server" Text="Run" OnClick="button_Click" OnClientClick="button_start()" />
...
<script type="text/javascript">
function button_start() {
setInterval(function () {
$.ajax({
url: 'StatusHandler.ashx',
data: { statusKeyId: '<%= ViewState["key"] %>' },
type: 'post',
dataType: 'json',
success: function (json) {
... process response
},
error: function () {
}
});
}, 1000);
}
</script>
...
default.aspx.cs
....
protected void button_Click(object sender, EventArgs e)
{
System.Threading.Thread.Sleep(2000);
for (int i = 0; i < 10; ++i)
{
System.Threading.Thread.Sleep(500);
// TODO: update progress status
}
// lblStatus.Text = "Done";
}
StatusHandler.ashx.cs:
public class StatusHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "application/json";
string statusKeyId = context.Request.Params["statusKeyId"];
if (statusKeyId != null)
{
System.Web.Script.Serialization.JavaScriptSerializer s = new System.Web.Script.Serialization.JavaScriptSerializer(GetStatusInfo(statusKeyId ));
string output = s.Serialize(info);
context.Response.Write(output);
return;
}
context.Response.Write("{test: \"empty\"}");
}
答案 0 :(得分:0)
问题不在于:为什么这不适用于Chrome,但为什么它可以在IE和Firefox中运行。
单击按钮时,浏览器会向服务器发送正常的http请求以替换整个页面。我想当时在页面上执行或不执行javascript的行为是未定义的,或者至少在不同的浏览器之间有所不同,正如您所注意到的那样。
更好的方法是使用异步请求(Ajax)调用服务器,以便页面在浏览器中保持活动状态。 然后,当您的StatusHandler应答时,您的长时间运行过程已准备就绪,您可以将浏览器重定向到可以从服务器获取结果页面的URL。