2

我遇到了一些代码,这些代码使用以下类型的referrer hack通过IE中的Javascript将referrer信息传递到弹出窗口:

    var targetName = "linkTarget";
    _win = window.open("", targetName, 'width=800,height=480,resizable=yes,status=yes,location=yes,toolbar=no');

    var _link;
    if (!document.getElementById("referrerHackLink")) {
        _link = document.createElement('a');
        _link.id = "referrerHackLink";
        document.body.appendChild(_link);
    }
    else {
        _link = document.getElementById("referrerHackLink");
    }

    _link.target = targetName;
    _link.href = url;
    _link.click();

HTTP Referrer 和 IE7 和 IE8

http://webbugtrack.blogspot.com/2008/11/bug-421-ie-fails-to-pass-http-referer.html

有趣的是,当我尝试对某些 URI(包括 localhost)使用该方法时,IE9 和 IE10 会模糊弹出窗口并导航到主窗口中的目标 URL。

你可以在这里找到一个例子:http: //jsfiddle.net/geoffreymoller/JKXzk/

关于为什么 localhost 版本可能会更改弹出窗口和目标信息的任何想法?

4

1 回答 1

0

_win = window.open("", targetName, 'width=800,height=480,resizable=yes,status=yes,location=yes,toolbar=no');

我认为 IE 中的窗口名称仅限于名称_self, _top, _blank, etc... ,因此任何与预期列表不同的名称都可能被视为_self

于 2013-01-12T01:38:51.667 回答