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