zoukankan      html  css  js  c++  java
  • chrome不支持对opener方法的调用?

    自从开始做Web开发后,我就经常在不同的浏览器间换来换去,目前主要使用四种浏览器,分别是IE、Firefox、Chrome和Safari,这四种浏览器各有千秋,说不上谁最好,如今开发的网站,我都会用这四种浏览器测试下效果。最近做一个页面需要用到opener的方法进行调用,我把代码精简了一下,这是主页面main.htm:

    <!DOCTYPE html>
    <html>
    <head>
    <title>Main</title>
    <script>
    function remote() {
        win2 = window.open("remote.htm", "");
    }
    
    function RemoteCallTest() {
        document.getElementById("text-test").innerHTML = "I am called by Remote.";
    }
    </script>
    </head>
    <body>
    <form>
    <input type="button" value="Open Window" onClick="remote()">
    </form>
    <span id="text-test">I am not called.</span>
    </body>
    </html>

    这是要打开的页面remote.htm:

    <!DOCTYPE html>
    <html>
    <head>
    <title>Remote</title>
    </head>
    <body>
    <p>
    <a href="javascript:window.opener.RemoteCallTest()">Call Test</a>
    </p>
    </body>
    </html>

    打开的页面会回调主页面的一个方法,可以来做一个局部刷新什么的。我直接用前面提到的四大浏览器打开main.htm进行测试,发觉Firefox,Safari很顺利通过,而IE则出现一个警告,点“允许”后也通过了,而Chrome却不行,十分奇怪。后来考虑:是否因为浏览器出自于安全的原因禁止了这种调用?于是查看Chrome的设置,却也没发现相关的选项。后来考虑到是不是因为直接打开本地文件而不是打开网站的缘故?我创建了一个简单的MVC程序,调试了一下后发觉居然可以了。代码太简单,上面的改一改就行了,就不贴了。

  • 相关阅读:
    009——数组(九) each list array_map array_walk array_walk_recursive
    008——数组(八)删除添加数组 得到数组键名键值
    laravel怎么获取到public路径
    laravel中composer镜像服务的方式
    logback的使用和logback.xml详解
    log4j-over-slf4j工作原理详解
    java
    【Log】logback指定配置文件(二)
    logback 中文手册
    logback logback.xml常用配置详解(三) <filter>
  • 原文地址:https://www.cnblogs.com/guogangj/p/2729614.html
Copyright © 2011-2022 走看看