在Internet Explorer中的AJAX请求后,window.location不起作用
我试图通过网页上的链接启动ClickOnce应用程序。 链接必须转到服务器才能启动应用程序之前请求事务GUID。 代码的工作原理如下:
function clickHandler() { $.post('/gettransactionid.aspx', function(tranId) { console.log("BEFORE"); window.location = "/deploy/Company.Domain.Product.application?" + tranId; console.log("AFTER"); }); return false; }
这在Firefox中运行得非常好,但在IE中它会导致导航并且不会打开clickonce应用程序。 在IE8开发工具的控制台窗口中显示控制台.log BEFORE和AFTER。 任何帮助将不胜感激,因为我花了4个小时试图解决它与各种黑客!
我试过了:
- 将window.location更改为window.open。 这只会启动窗口一秒钟,无法启动应用程序。
- 警告而不是window.location。 这没什么。
- 针对IE7,IE8和IE9。
- 通过将浏览器安全性添加到队列并在根窗口上下文中处理window.location来绕过浏览器安全性。
- 我检查过gettransactionid.aspx返回事务ID。
- 在Firefox中完成它 – 它工作正常。
在Microsoft的文档中找到答案:
如果您已经开发了一个使用Active Scripting启动ClickOnce应用程序的自定义Web页面,您可能会发现该应用程序无法在某些计算机上启动。 Internet Explorer包含一个名为“自动提示文件下载”的设置,该设置会影响此行为。 此选项菜单中的“安全”选项卡上提供了此设置,该设置会影响此行为。 它被称为自动提示文件下载,它列在下载类别下面。 对于Intranet网页,该属性默认设置为“启用”,默认情况下,“Internet网页”设置为“禁用”。 当此设置设置为“禁用”时,将阻止以编程方式激活ClickOnce应用程序的任何尝试(例如,通过将其URL分配给document.location属性)。 在这种情况下,用户只能通过用户启动的下载启动应用程序,例如,通过单击设置为应用程序URL的超链接。
更新2011年9月1日:具有讽刺意味的是,由于“自动提示下载”被删除,现在已经完全破坏了IE9。
回答!
如果您已经开发了一个使用Active Scripting启动ClickOnce应用程序的自定义Web页面,您可能会发现该应用程序无法在某些计算机上启动。 Internet Explorer包含一个名为“自动提示文件下载”的设置,该设置会影响此行为。 此选项菜单中的“安全”选项卡上提供了此设置,该设置会影响此行为。 它被称为自动提示文件下载,它列在下载类别下面。 对于Intranet网页,该属性默认设置为“启用”,默认情况下,“Internet网页”设置为“禁用”。 当此设置设置为“禁用”时,将阻止以编程方式激活ClickOnce应用程序的任何尝试(例如,通过将其URL分配给document.location属性)。 在这种情况下,用户只能通过用户启动的下载启动应用程序,例如,通过单击设置为应用程序URL的超链接。
因此,请更改IE安全设置以打开自动提示文件下载。
我也有同样的问题。 一种可能的解决方案是将ajax请求从异步更改为同步。 如果这样做,则根本不需要“自动提示”。
尝试调用setTimeout
以稍后执行导航。
你应该为你的window.location添加一个完整的URL(包括http://
):-)
我刚才有同样的问题,这与我的FQDN中有一个下划线有关。 在FQDN中使用下划线是违法的,但只有Internet Explorer实际阻止它,而其他浏览器使其正常工作。 如果您有下划线,Internet Explorer将不会注册cookie …
如果那不是你的问题,我建议在window.location之前尝试一个e.preventDefault()来看看会发生什么。
尝试删除第一个斜杠:
window.location = "deploy/Company.Domain.Product.application?" + tranId;
也许IE认为你正试图从根部“部署”。 无论如何,我认为使用完整url是一种很好的做法=没有误解
我同意Mih,因为您不能对您的用户说改变他们的浏览器选项。 如果您使用异步请求,则可能在Internet Explorer中没问题。
您可以将$ .post更改为$ .ajax,如下所示:
$.ajax({ type: 'POST', url: url, ... async:false });
有关ajax的更多信息: http : //api.jquery.com/jQuery.ajax/