JS操作iframe里的dom(實(shí)例講解)
直接賦值如下代碼測(cè)試即可明白:
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>無(wú)標(biāo)題文檔</title>
</head>
<body>
<div class="line">====================注意:測(cè)試從這里開(kāi)始=========================</div>
<p id="pox">用來(lái)測(cè)試子窗體iframeA訪問(wèn)父窗體的某元素</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>先來(lái)演示:父窗體訪問(wèn)子窗體中的某方法或元素</p>
<p>總結(jié):父窗體訪問(wèn)子窗體的方法跟元素采用不同的方式</p>
<input type="button" onclick="frameDiv()" value="父窗體訪問(wèn)子窗體中的某元素" />
<input type="button" onclick="frameFun()" value="父窗體訪問(wèn)子窗體中的某方法" />
<script type="text/javascript">
//子窗口訪問(wèn)父窗口方法
function testP(ss){
alert(ss)
}
//取得iframe的元素
function getIframe(id){
return document.getElementById(id).contentWindow.document;
}
//父窗口訪問(wèn)子窗口元素
function frameDiv(){
getIframe("frameA").getElementById("ooxx").style.backgroundColor="#f00"
//window.frames["iframeA"].getElementById("ooxx").style.backgroundColor="#f00" //不能通過(guò)這種形式訪問(wèn)某元素
}
//父窗口訪問(wèn)子窗口方法
function frameFun(){
//getIframe("frameB").getsFun();//不能通過(guò)這種形式訪問(wèn)子窗體某方法
// 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>無(wú)標(biāo)題文檔</title>
</head>
<body>
<div id="ooxx">用來(lái)測(cè)試父窗體訪問(wèn)子窗體中的某元素</div>
<p id="divooxx">用來(lái)測(cè)試子窗口B訪問(wèn)窗體A的某元素</p>
<p>1.子窗口iframeA訪問(wèn)父窗口的某元素</p>
<input type="button" onclick="frameToPdiv()" value="子窗口訪問(wèn)父窗口的某元素" />
<input type="button" onclick="frameToPfun()" value="子窗口訪問(wèn)父窗口的某方法" />
<script type="text/javascript">
//子窗口訪問(wèn)父窗口的某元素
function frameToPdiv(){
parent.document.getElementById("pox").style.color="#fff";
parent.document.getElementById("pox").style.backgroundColor="#f0a0f0"
}
//子窗口訪問(wèn)父窗口方法
function frameToPfun(ss){
parent.testP("ssss");
}
//用于測(cè)試iframeB訪問(wèn)的方法
function testBA(){
alert("用于測(cè)試iframeB訪問(wèn)的方法")
}
</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>無(wú)標(biāo)題文檔</title>
</head>
<body>
<p>二:測(cè)試子窗體間相互訪問(wèn)某方法或元素</p>
<input type="button" value="子窗體B訪問(wèn)子窗體A的某元素" onclick="frameTframeDiv()" />
<input type="button" value="子窗體B訪問(wèn)子窗體A的某方法" onclick="frameTframeFun()" />
<script type="text/javascript">
//子窗體B訪問(wèn)子窗體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");//子窗體訪問(wèn)父窗體方法
_bframe.getElementById("divooxx").style.color="#a0c0f0";
_bframe.getElementById("divooxx").style.backgroundColor="#000";
}
//子窗體B訪問(wèn)子窗體A的某方法
function frameTframeFun(){
window.parent.frames["frameA"].testBA();
}
</script>
<script type="text/javascript">
function getsFun(){
return "sssssss";
}
//getFun()
</script>
</body>
</html>
- 整理JavaScript對(duì)DOM中各種類(lèi)型的元素的常用操作
- JavaScript利用HTML DOM進(jìn)行文檔操作的方法
- JavaScript操作HTML DOM節(jié)點(diǎn)的基礎(chǔ)教程
- JavaScript對(duì)HTML DOM使用EventListener進(jìn)行操作
- 詳解JavaScript操作HTML DOM的基本方式
- 你所不了解的javascript操作DOM的細(xì)節(jié)知識(shí)點(diǎn)(一)
- JavaScript DOM操作表格及樣式
- js使用DOM操作實(shí)現(xiàn)簡(jiǎn)單留言板的方法
- JavaScript操作DOM元素的childNodes和children區(qū)別
- javascript中HTMLDOM操作詳解
- JavaScript基礎(chǔ)語(yǔ)法、dom操作樹(shù)及document對(duì)象
- 淺析JS操作DOM的一些常用方法
相關(guān)文章
js 點(diǎn)擊按鈕彈出另一頁(yè),選擇值后,返回到當(dāng)前頁(yè)
js 點(diǎn)擊按鈕彈出另一頁(yè),選擇值后,返回到當(dāng)前頁(yè),其實(shí)主要用于cms系統(tǒng)中,相關(guān)文章的搜索,要在已上傳目錄中選擇一些圖片等。2010-05-05JS實(shí)現(xiàn)可點(diǎn)擊展開(kāi)與關(guān)閉的左側(cè)廣告代碼
這篇文章主要介紹了JS實(shí)現(xiàn)可點(diǎn)擊展開(kāi)與關(guān)閉的左側(cè)廣告代碼,通過(guò)鼠標(biāo)onClick事件調(diào)用自定義javascript函數(shù)實(shí)現(xiàn)頁(yè)面元素及樣式的顯示與隱藏效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-09-09uniapp中scroll-view實(shí)現(xiàn)自動(dòng)滾動(dòng)到最底部的方法
這篇文章主要給大家介紹了關(guān)于uniapp中scroll-view實(shí)現(xiàn)自動(dòng)滾動(dòng)到最底部的相關(guān)資料,在uniapp日常開(kāi)發(fā)的過(guò)程中經(jīng)常會(huì)有局部滾動(dòng)的需求,而scroll-view組件正好可以滿足這一需求,需要的朋友可以參考下2023-10-10使用js在layui中實(shí)現(xiàn)上傳圖片壓縮
這篇文章主要介紹了使用js在layui中實(shí)現(xiàn)上傳圖片壓縮,layui 是一款采用自身模塊規(guī)范編寫(xiě)的前端 UI 框架,js上傳圖片壓縮百度有很多方法,,需要的朋友可以參考下2019-06-06如何通過(guò)Proxy實(shí)現(xiàn)JSBridge模塊化封裝
這篇文章主要介紹了如何通過(guò)Proxy實(shí)現(xiàn)JSBridge模塊化封裝,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10