6

我一直在研究这个问题,虽然在各种论坛上有很多关于类似问题的帖子,但没有一个问题或解决方案与我的完全匹配。

我有一个应用程序已成功使用以下功能在完成弹出窗口后重定向回父窗口。最近一直在研究其他浏览器的兼容性(让系统可以通过iPad使用),发现在使用Safari或者Chrome的时候这个功能有问题。

父页面是一些数据库信息的摘要,用户单击链接打开一个窗口(通过 window.open)以查看更详细的数据。完成后,子窗口上有一个链接,该链接会刷新父级上的数据(部分是为了确保在您返回父级时显示正确的数据)并关闭子级。

Safari 中的控制台报告“'window.opener.location.href' 的结果不是函数”。我曾尝试使用上述和“window.opener.document.location.href”和“window.opener.window.location.href”(取自网上提供的其他解决方案)但没有成功。

我知道有些人的这个功能运行良好,而另一些人则有这种问题。我想知道这种特定情况是否有任何答案。

这是我的功能:

function quicklink(url) {
window.opener.document.location.href(url);
self.close();
}

这从 IE7、8 和 9 的第一天开始就有效,但在 Safari(适用于 Windows 或 iPad)或 Chrome 中无效。

有任何想法吗?

4

2 回答 2

21

href是属性,不是方法。只需为其分配 URL:

window.opener.document.location.href = url;

这也适用于 IE。它也是那里的一个属性,即使它允许您将它用作方法。

于 2011-10-11T00:13:21.157 回答
0

使用下面的代码来达到预期的效果。

家长:

<script language="javascript">

function open_a_window() 
{
    var w = 200;
        var h = 200;
        var left = Number((screen.width/2)-(w/2));
        var tops = Number((screen.height/2)-(h/2));

        window.open("window_to_close.html", '', 'toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=no, resizable=no, copyhistory=no, width='+w+', height='+h+', top='+tops+', left='+left);

   return false;
}

// opener:
window.onmessage = function (e) {
  if (e.data === 'location') {
    window.location.replace('https://www.google.com');
  }
};

</script>

<input type="button" onclick="return open_a_window();" value="Open New Window/Tab" />

弹出:

<!DOCTYPE html>
<html>
<body onload="quitBox('quit');">

<h1>The window closer:</h1>

<input type="button" onclick="return quitBox('quit');" value="Close This Window/Tab" /> 


<script language="javascript">

function quitBox(cmd) 
{      
    if (cmd=='quit')    
    {   
       window.opener.postMessage('location', '*');
       window.open(location, '_self').close();    
    }     
    return false;   
}

</script>

</body>
</html>
于 2019-12-05T10:54:00.103 回答