我有一个带有 iframe 的页面,其源页面位于单独的域中。源页面有时会生成警报。当它这样做时,它会停止它正在做的事情,直到用户单击“确定”来发出警报。
我想做的是以编程方式在此警报上单击“确定”,以便源页面可以恢复使用。这可能吗?
我有一个带有 iframe 的页面,其源页面位于单独的域中。源页面有时会生成警报。当它这样做时,它会停止它正在做的事情,直到用户单击“确定”来发出警报。
我想做的是以编程方式在此警报上单击“确定”,以便源页面可以恢复使用。这可能吗?
JavaScript 是单线程的,这意味着当你调用一个函数时,它会阻塞直到它返回。当您调用 alert() 时,它会将控制权传递给决定如何处理它的浏览器。弹出 UI 对话框的不是 Javascript,而是浏览器。在浏览器收到“OK”事件并返回控制权之前,alert() 不会返回。javascript 线程停止,直到发生这种情况。
因此,出于以上段落中所述的至少两个不同的原因,答案是否定的:)
我很确定这是不可能的。
如果您在代码中使用 no-op 覆盖警报会发生什么?
例如
<script>
// uncomment next line to swallow alerts
// function alert(nope) { return; }
<script>
<script>
$(document).ready(function() { alert("Hello, world!"); });
</script>
注释掉该行后,会出现警报。带有注释的行,警报不会出现。
如果您知道警报的文本并且不介意弄脏,那么您应该没有问题。
你可以用你自己的覆盖 iframe 窗口的警报,并做一些事情来影响..
document.getElementById("InnerFrameName").contentWindow.alert = function(){
if (arguments[0].toLowerCase() == "innerframe alert text")
return; //supress
else
alert(arguments[0]);
};
编辑:我用代理处理程序做了一个小测试(它在 asp.net/c# 中,但你应该明白)......
我的测试中的外部页面是一个 w3 页面,带有一个显示警报的按钮,警报现在通过用户定义的函数传递。
我敢肯定这比你想得到的要脏得多。
页:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title>Hello From MyPage</title>
<script type="text/javascript">
function frameLoaded() {
document.getElementById("InnerFrameName").contentWindow.alert = function() {
if (arguments[0].toLowerCase() == "i am an alert box!!") {
alert("MESSAGES WOULD BE SUPRESSED: " + arguments[0]);
return; //supress
} else {
alert(arguments[0]);
}
};
}
</script>
</head>
<body onload="alert('Hello from an unsupressed top level frame message!');">
<form id="form1" runat="server">
<div>
<h1>Internal Page (Top Level)</h1>
<hr />
<iframe id="InnerFrameName" onload="frameLoaded();" src="PageProxy.ashx?externalURI=http://www.w3schools.com/JS/tryit_view.asp?filename=tryjs_alert"
style="width: 800px; height: 600px;">Derp!...</iframe>
</div>
</form>
</body>
</html>
代理处理程序:
<%@ WebHandler Language="C#" Class="PageProxy" %>
using System;
using System.Web;
public class PageProxy : IHttpHandler {
public void ProcessRequest (HttpContext context) {
byte[] externalPage = new System.Net.WebClient().DownloadData(context.Request["externalURI"]);
context.Response.OutputStream.Write(externalPage, 0, externalPage.Length);
context.Response.End();
}
public bool IsReusable {
get {
return false;
}
}
}
我对此表示高度怀疑。如果通过单独的域,您是指您无法控制的域吗?
如果您确实有控制权,则可以将警报更改为您可以控制的模态 Javascript 框。
解决烦人的 JavaScript 问题的最佳选择是使用Greasemonkey之类的客户端脚本工具覆盖它。