No debería tener un problema si conoce el texto de la alerta y no le importa ensuciar.
Puede anular alerta de la ventana de marco flotante con su propio y hacer algo al efecto de ..
document.getElementById("InnerFrameName").contentWindow.alert = function(){
if (arguments[0].toLowerCase() == "innerframe alert text")
return; //supress
else
alert(arguments[0]);
};
Editar: hice una pequeña prueba con un controlador de proxy (está en asp.net/c# pero debe tener la idea) ...
La página externa en mi prueba es una página w3 con un botón que muestra una alerta, la alerta ahora se pasa a través de la función definida por el usuario.
Estoy seguro de que esto es mucho más sucio de lo que te gustaría obtener.
Página:
<%@ 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>
Proxy Handler:
<%@ 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;
}
}
}
Confirmado mis sospechas. Tendré que usar algo adicional o en lugar de JavaScript para este. – moffdub
El subproceso de JavaScript no se detiene, los mensajes siguen siendo bombeados y cualquier temporizador o cambio asincrónico disparará controladores de eventos, y JS en esos controladores aún se ejecutará. –