zoukankan      html  css  js  c++  java
  • js调用父框架函数

    if (window.parent && window.parent.frames["frame_main"]) {
    alert(window.parent.frames["frame_main"]);
    window.parent.frames["frame_main"]..location.reload();
    }else
    {
    window.parent.frames.item("frame_main").location.reload();
    }

    if (window.parent && window.parent.frames["frame_main"]) {
    alert(window.parent.frames["frame_main"]);
    window.parent.frames["frame_main"].location.reload();
    }
    else if (window.parent && window.parent.frames.item("frame_main")) {
    window.parent.frames.item("frame_main").location.reload();
    }
    //刷新父窗口
    window.parent.frame_main.location.reload();

    iframe父子兄弟之间调用传值(contentWindow && parent)

    学习一个知识点最好的方法就是自己动手去的实现一些简单的helloworld,虽然可以在网上可以找到很多总结,但自己实现的过程才是自己的,期间遇到问题并解决问题的过程也会让自己记忆理解更加深刻。

     

    iframe的调用包括以下几个方面:(调用包含html dom,js全局变量,js方法)

    主页面调用iframe;

    iframe页面调用主页面;

    主页面的包含的iframe之间相互调用;

     

    主要知识点

    1:document.getElementById("ii").contentWindow 得到iframe对象后,就可以通过contentWindow得到iframe包含页面的window对象,然后就可以正常访问页面元素了;

    2:$("#ii")[0].contentWindow  如果用jquery选择器获得iframe,需要加一个【0】;

    3:$("#ii")[0].contentWindow.$("#dd").val() 可以在得到iframe的window对象后接着使用jquery选择器进行页面操作;

    4:$("#ii")[0].contentWindow.hellobaby="dsafdsafsdafsdafsdafsdafsadfsadfsdafsadfdsaffdsaaaaaaaaaaaaa"; 可以通过这种方式向iframe页面传递参数,在iframe页面window.hellobaby就可以获取到值,hellobaby是自定义的变量;

    5:在iframe页面通过parent可以获得主页面的window,接着就可以正常访问父亲页面的元素了;

    6:parent.$("#ii")[0].contentWindow.ff; 同级iframe页面之间调用,需要先得到父亲的window,然后调用同级的iframe得到window进行操作;

     

    源码

    main.html

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>显示图表</title>
    <script src="http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        var gg="dsafdsafdsafdsafsdaf";
        function ggMM() {
            alert("2222222222222222222222222222222");
        }
        function callIframeMethod() {
            //document.getElementById("ii").contentWindow.test();
            $("#ii")[0].contentWindow.test(); //用jquery调用需要加一个[0]
        }
        function callIframeField() {
            alert($("#ii")[0].contentWindow.ff);
        }
        function callIframeHtml() {
            alert($("#ii")[0].contentWindow.$("#dd").val());
            //alert($("#ii")[0].contentWindow.document.getElementById("dd").value);
            //alert($("#ii")[0].contentWindow.document.getElementById("dd").value);            
        }  
        function giveParameter() {
            $("#ii")[0].contentWindow.hellobaby="dsafdsafsdafsdafsdafsdafsadfsadfsdafsadfdsaffdsaaaaaaaaaaaaa";
        }
    </script>
    </head>
    <body>
        <a href="#" onClick="giveParameter();">参数传递</a>
        <a href="#" onClick="callIframeMethod();">调用子iframe方法</a>
        <a href="#" onClick="callIframeField();">调用子iframe变量</a>
        <a href="#" onClick="callIframeHtml();">调用子iframe组件</a></br
        <iframe id="ii" src="frame.htm" width="100%" frameborder="0"></iframe>
        <iframe id="new" src="newFrame.htm" width="100%" frameborder="0"></iframe>
    </body>
    </html>

    frame.htm

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>显示图表</title>
    <script src="http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js" type="text/javascript"></script>
    <script type="text/javascript">
     
    var ff="adfdasfdsafdsafdsaf";
    function test() {
        alert($("#dd").val());
    }
    function callMainField() {
        alert(parent.gg);
    }
    function callMainMethod() {
        parent.ggMM();
    }
    function callMainHtml() {
        alert(parent.$("#ii").attr("id"));
    }
    function getParameter() {
        alert(window.hellobaby);
    }
    </script>
    </head>
    <body>
        <a href="#" onClick="getParameter();">接受参数</a>
        <a href="#" onClick="callMainMethod();">调用子iframe方法</a>
        <a href="#" onClick="callMainField();">调用主窗口变量</a>
        <a href="#" onClick="callMainHtml();">调用子iframe组件</a>  
        <input id="dd" type="text" value="1111111111"/>
    </body>
    </html>

     兄弟iframe页面 newIframe.htm

    复制代码
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>显示图表</title>
    <script src="http://www.cnblogs.com/http://www.cnblogs.com/scripts/jquery-1.7.1.min.js" type="text/javascript"></script>
    <script type="text/javascript">
    function callLevelFrame() {
        var ff=parent.$("#ii")[0].contentWindow.ff;
        alert(ff);
    }
    </script>
    </head>
    <body>
        <a href="#" onClick="callLevelFrame();">调用兄弟iframe</a>    
        <input id="nn" type="text" value="sdafsdfsa"/>
    </body>
    </html>
    复制代码

    结语:

    我对jquery html css的理解还需要很多提高,自己总结的东西对大牛来说也很幼稚,但大牛之路都是如此总结向上提高的,我不怕这种幼稚。

     
     
    分类: 前端

    js调用父框架函数与弹窗调用父页面函数的方法

    调用父级中的 aaa的函数


    子页面中:

    onclick="window.parent.frames.aaa()"

    父页面中:

    function aaa()
    {
    alert(‘bbbbb’);
    }

    ----------------------------------------------

    frame框架里的页面要改其他同框架下的页面或父框架的页面就用parent
    window.opener引用的是window.open打开的页面的父页面。

    window.frames对象可以引用iframe里的页面,也可以引用frameset里的页面.

    可以这样
    window.frames[0].document.getElementById(‘xx’);
    可以这样
    window.frames[0].document.body.innerHTML;

    frm = window.parent.window.frames[‘uploadFrame’];
    frmDocument = frm.document;
    frm.sb(3); //sb 是uploadFrame页面里的一个函数

    对于firefox
    如果你遇到报错:parent.document.frames has no properties
    换为如下代码就可以了,这个代码IE,ff兼容. frm = window.parent.window.frames[‘uploadFrame’];其实 frames 集合并不是挂在 document 而是挂在 window 对象下.

    注意这样修改frame里的页面有限制,就是必须是同域下的,否则无法访问
    如果是同一域下,但是子域名不同,那么涉及到的js,html文件都加上一句。
    document.domain = xxx.com [这里填写你的域名]

    document.getElementById(‘iframeid’).contentWindow.document.getElementById(‘someelementid’);

    js弹窗页面后调用父页面函数

    (例如:调用父页面函数test2())
    window.opener.test2();

    框架子页面调用上一个页面方法

    (例如:上一页面的框架frame名为menuBar,调用onhook()函数)
    window.top.frames["menuBar"].onhook();

    js弹窗页面调用父页面框架子页面函数

    (如:弹窗页面调用,frame名为menuBar)
    window.opener.top.frames['menuBar'].onhook();

  • 相关阅读:
    struts2之JSP与Action的关系
    struts2之基本配置
    Android笔记之BroadCast判断网络状况
    Android笔记之监听左右滑动事件
    Android笔记之转到主线程运行
    springboot项目启动报错 Failed to configure a DataSource: 'url' attribute is not specified and no embedde
    centos6 初次安装成功,未显示eth0网卡的信息
    layerui上传文件
    判断当前浏览器类型
    jquery重置下拉框
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3300953.html
Copyright © 2011-2022 走看看