iframe和父窗体之间的互相监听方法
生活随笔
收集整理的這篇文章主要介紹了
iframe和父窗体之间的互相监听方法
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
例如:一個(gè)父窗體點(diǎn)擊了個(gè)提交表單事件,同時(shí)要將提交的服務(wù)器返回處理結(jié)果顯示在父窗體的iframe頁(yè)面中,父窗體通過(guò)獲得iframe中返回的結(jié)果來(lái)處理父窗體的部分?jǐn)?shù)據(jù)。此時(shí)就要監(jiān)聽(tīng)iframe的內(nèi)容變更。
在IE下直接可以用
$get("#frame_hidden").onreadystatechange = function () {if ($get("#frame_hidden").readyState && $get("#frame_hidden").readyState == "complete") {var responseText = $get("#frame_hidden").contentDocument.getElementById("divMes").innerHTML;eval("var d=".concat(responseText));if (d.status.toUpperCase() == "Y") {//添加成功時(shí)的操作var data = "path=" + escape(navPointer);DataLoad(data);obj.parentNode.removeChild($get("#upFile"));$get("#btnOpen").style.display = "inline";obj.style.display = "none";} else if (d.status.toUpperCase() == "N") {alert(d.err);}}}} 就可以監(jiān)聽(tīng)到,但這個(gè)方法不兼容firefox,google,opera等瀏覽器,在這些瀏覽器下onreadystatechange這個(gè)事件就如同癱患了 如簡(jiǎn)單的操作,可以給iframe的onload事件進(jìn)行賦值如:iframe.οnlοad=iframe.onreadystatecnage=function(){//。。。。}?這個(gè)其實(shí)起不了真正的監(jiān)聽(tīng)作用,它只是在每次iframe加載時(shí)處理下 我這次解決的辦法是在iframe中寫js,然后結(jié)合父窗體的js二者產(chǎn)生交互來(lái)實(shí)現(xiàn)。 如: var responseText = $get("#divMes").innerHTML;eval("var d=".concat(responseText));if (d.status.toUpperCase() == "Y") {//添加成功時(shí)的操作var data = "path=" + escape(parent.navPointer);parent.DataLoad(data);//這是調(diào)用父窗體的改變處理數(shù)據(jù)的方法parent.document.getElementById("upLoad").parentNode.removeChild(parent.document.getElementById("upFile"));parent.document.getElementById("btnOpen").style.display = "inline";parent.document.getElementById("upLoad").style.display = "none";} else if (d.status.toUpperCase() == "N") {alert(d.err);}轉(zhuǎn)載于:https://www.cnblogs.com/solomon_Blog/archive/2011/09/29/2195334.html
總結(jié)
以上是生活随笔為你收集整理的iframe和父窗体之间的互相监听方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ASP导出EXCEL乱码?试试这个
- 下一篇: IT职场新人第一课:我的吐槽+我学到的