DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> JS操作iframe裡的dom的介紹
JS操作iframe裡的dom的介紹
編輯:JavaScript綜合知識     

本篇主要是對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>

 

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved