萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> JS操作iframe裡的dom的介紹

JS操作iframe裡的dom的介紹

本篇主要是對JS操作iframe裡的dom進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

直接賦值如下代碼測試即可明白:

 

1.html:

代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>無標題文檔</title>

</head>

 

<body>

<div class="line">====================注意:測試從這裡開始=========================</div>

<p id="pox">用來測試子窗體iframeA訪問父窗體的某元素</p>

<div class="line">====================iframe分割線=========================</div>

<iframe src="a.html" width="100%" frameborder="0" id="frameA" name="frameA"></iframe>

<iframe src="b.html" name="iframeB" width="100%" frameborder="0" id="frameB"></iframe>

<div class="line">====================iframe分割線=========================</div>

<p>先來演示:父窗體訪問子窗體中的某方法或元素</p>

<p>總結:父窗體訪問子窗體的方法跟元素采用不同的方式</p>

<input type="button" onclick="frameDiv()" value="父窗體訪問子窗體中的某元素" />

<input type="button" onclick="frameFun()" value="父窗體訪問子窗體中的某方法" />

<script type="text/javascript">

    //子窗口訪問父窗口方法

    function testP(ss){

        alert(ss)

    }

    //取得iframe的元素

    function getIframe(id){

        return document.getElementById(id).contentWindow.document;

    }

    //父窗口訪問子窗口元素

    function frameDiv(){

        getIframe("frameA").getElementById("ooxx").style.backgroundColor="#f00"

        //window.frames["iframeA"].getElementById("ooxx").style.backgroundColor="#f00"  //不能通過這種形式訪問某元素

    }

    //父窗口訪問子窗口方法

    function frameFun(){

        //getIframe("frameB").getsFun();//不能通過這種形式訪問子窗體某方法

       // window.frames["iframeB"].getsFun();

  alert(window.frames["iframeB"].getsFun());

    }

</script> 

</body>

</html>

 

 

a.html

代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>無標題文檔</title>

</head>

 

<body>

<div id="ooxx">用來測試父窗體訪問子窗體中的某元素</div>

<p id="divooxx">用來測試子窗口B訪問窗體A的某元素</p>

<p>1.子窗口iframeA訪問父窗口的某元素</p>

<input type="button" onclick="frameToPdiv()" value="子窗口訪問父窗口的某元素" />

<input type="button" onclick="frameToPfun()" value="子窗口訪問父窗口的某方法" />

<script type="text/javascript">

    //子窗口訪問父窗口的某元素

    function frameToPdiv(){

        parent.document.getElementById("pox").style.color="#fff";

        parent.document.getElementById("pox").style.backgroundColor="#f0a0f0"

    }

    //子窗口訪問父窗口方法

    function frameToPfun(ss){

        parent.testP("ssss");

    }

    //用於測試iframeB訪問的方法

    function testBA(){

        alert("用於測試iframeB訪問的方法")

    }

</script>

</body>

</html>

 

 

b.html

 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>無標題文檔</title>

</head>

 

<body>

<p>二:測試子窗體間相互訪問某方法或元素</p>

<input type="button" value="子窗體B訪問子窗體A的某元素" onclick="frameTframeDiv()" />

<input type="button" value="子窗體B訪問子窗體A的某方法" onclick="frameTframeFun()" />

<script type="text/javascript">

    //子窗體B訪問子窗體A的某元素

    function frameTframeDiv(){

        //parent.document.getElementById("frameA").contentWindow.document.getElementById("divooxx")

.style.color="#a0c0f0";

        //parent.document.getElementById("frameA").contentWindow.document.getElementById("divooxx")

.style.backgroundColor="#000"

        var _bframe=parent.getIframe("frameA");//子窗體訪問父窗體方法

        _bframe.getElementById("divooxx").style.color="#a0c0f0";

        _bframe.getElementById("divooxx").style.backgroundColor="#000";

    }

    //子窗體B訪問子窗體A的某方法

    function frameTframeFun(){

            window.parent.frames["frameA"].testBA();

    }

</script>

<script type="text/javascript">

    function getsFun(){

        return "sssssss";

    }

    //getFun()

</script>

</body>

</html>

 

copyright © 萬盛學電腦網 all rights reserved