Nie powinieneś mieć problemu, jeśli znasz tekst alarmu i nie masz nic przeciwko zabrudzeniu.
Można zastąpić zaalarmować okna iframe z własnych i zrobić coś do skutku ..
document.getElementById("InnerFrameName").contentWindow.alert = function(){
if (arguments[0].toLowerCase() == "innerframe alert text")
return; //supress
else
alert(arguments[0]);
};
Edit: zrobiłem mały test z obsługi proxy (nie jest to jednak w asp.net/c# powinieneś dostać pomysł) ...
Strona zewnętrzna w moim teście to strona w3 z przyciskiem, który wyświetla alert, alert jest teraz przekazywany przez funkcję zdefiniowaną przez użytkownika.
Jestem pewien, że jest o wiele bardziej brudny niż chciałbyś dostać.
strony:
<%@ 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;
}
}
}
Potwierdziłem moje podejrzenia. W tym celu będę musiał użyć czegoś oprócz lub zamiast JavaScript. – moffdub
Wątek JavaScript nie jest zatrzymywany, wiadomości nadal są pompowane, a wszelkie liczniki czasu lub asynchroniczne zmiany nadal będą uruchamiały procedury obsługi zdarzeń, a JS w tych programach obsługi nadal będzie działał. –