微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

window.open的子级不会在父窗口中调用函数

如何解决window.open的子级不会在父窗口中调用函数

| parent.html
<html>
    <head>
        <script type=\"text/javascript\">
            function openWin()
            {
                myWindow=window.open(\'child.html\',\'\',\'width=200,height=100\');
            }
            function callback(){
                alert(\"test\");
            }
        </script>
    </head>
    <body>
        <input type=\"button\" value=\"Open \'myWindow\'\" onclick=\"openWin()\" />
    </body>
</html>
child.html
<html>
    <head>
       <script type=\"text/javascript\">
          window.opener.callback();
       </script>
    </head>
    <body>
    </body>
</html>
问题是子页面在FF,IE中而不是在Chrome中调用页面的回调函数。 任何想法 ?     

解决方法

发生问题是由于Chrome安全性错误。域,协议和端口必须匹配。但是,从本地文件系统打开页面时也会发生这种情况。 从服务器打开页面,应该没有任何问题。     ,问题可能是chrome如何运行javascript的方式。 Chrome浏览器有时会如此快且较早地运行js,甚至DOM还没有准备好进行操作。在您的child.html中尝试一下
<script type=\"text/javascript\">
setTimeout(function(){window.opener.callback();},100);
</script>
我不确定这是否对您确切,我在chrome上使用jQuery.ready()遇到了此问题。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。