欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

关于使用iframe的父子页面进行简单的相互传值

程序员文章站 2022-04-09 21:27:55
当一个页面使用了iframe作为嵌套时,如何想要将父页面的数据传给iframe子页面,那iframe所指向的呢个子页面是怎么获取呢,又或者子页面的数据要给父页面使用,那么父页面又如何获取子页面的数据呢?下面根据这种情况作了一个简单的demo案例: 父页面是parentPage.html,子页面是ch ......

当一个页面使用了iframe作为嵌套时,如何想要将父页面的数据传给iframe子页面,那iframe所指向的呢个子页面是怎么获取呢,又或者子页面的数据要给父页面使用,那么父页面又如何获取子页面的数据呢?下面根据这种情况作了一个简单的demo案例:

父页面是parentpage.html,子页面是childpage.html。

1、情况一:父页面获取子页面传入的数据(子页面给父页面传值)

父页面:

//获取子页面传入的数据
 function getchildvalue(obj){
   document.getelementbyid('texts').innertext = obj;
 }

子页面:

//给父页面传数据
var txt = '我是子界面主动传值给父界面的数值';
parent.getchildvalue(txt); //getvalue是父界面的js 方法

 

2、情况二:子页面获取父页面的数据(父页面给子页面传值)

父页面:

//给子页面传入数据
function tochildvalue(){
    var txt = '这是父页面给子页面的数据';
    return txt;
}

子页面:

//获取父页面传来的数据
var getparentvule = window.parent.tochildvalue();
console.log(getparentvule)

具体传值的数据根据自己的项目要求修改,下面放上两个页面的完整代码:

父页面parentpage.htm

<!doctype html>
<html>
    <head>
        <meta charset="utf-8">
        <title>父页面</title>
        <style type="text/css">
            .box{
                width: 600px;
                height: 400px;
                margin: 10px auto;
            }
            h3{
                font-size: 16px;
            }
            .cont{
                width: 100%;
            }
            .cont h4{
                font-size: 14px;
            }            
            .cont #texts{
                width: 100%;
                line-height: 22px;
                font-size: 13px;
                color: #2e2d3c;
            }
            
            iframe{
                /*只是隐藏,但任然保留dom结构*/
                visibility: hidden;  
            }
        </style>
    </head>
    <body>
        <div class="box">
            <h3>这是父页面</h3>
            <div class="cont">
                <h4>这是从子页面传入的数据:</h4>
                <div id="texts"></div>
                <iframe src="childpage.html" width="1px" height="1px" class="myiframe" name="myiframe"></iframe>
            </div>
        </div>
        
        
        <script type="text/javascript">
            //获取子页面传入的数据
            function getchildvalue(obj){
                document.getelementbyid('texts').innertext = obj;
            }
            
            //给子页面传入数据
            function tochildvalue(){
                var txt = '这是父页面给子页面的数据';
                return txt;
            }
        </script>
    </body>
</html>

 

 子页面childpage.html

<!doctype html>
<html>
    <head>
        <meta charset="utf-8">
        <title>子页面</title>
        <style type="text/css">
            .box{
                width: 600px;
                height: 400px;
                margin: 10px auto;
            }
            h3{
                font-size: 16px;
            }
        </style>
    </head>
    <body>
        <div class="box">
            <h3>这是子页面</h3>
        </div>
        
        
        <script type="text/javascript">
            //给父页面传数据
            var txt = '我是子界面主动传值给父界面的数值';
            parent.getchildvalue(txt); //getvalue是父界面的js 方法
            
            
            //获取父页面传来的数据
            var getparentvule = window.parent.tochildvalue();
            console.log(getparentvule)
            
        </script>
    </body>
</html>