老狗—— iframe子窗口,父窗口,左右窗口js函數互調

iframe裏面的頁面調用父窗口,左右窗口js函數的方法

① 實現iframe內部頁面直接調用該iframe所屬父窗口自定義函數的方法。

比如有A窗口,A內有個iframe B,B裏面的裝載的是C頁面,這時C要直接調用A裏面的一個自定義函數 fun();
那麼只要在C頁面中寫如下JS函數就可以了:
window.parent.fun();
如果fun()有參數也可以直接傳遞合適的參數進去
例如:
window.parent.POPUP(‘bigFram’);

//修改父窗口控件屬性
window.parent.document.getElementById('frmright').src = window.parent.document.getElementById('frmrightsrc').value;
//調用父窗口函數
window.parent.fun('xxxx');
//父窗口調用iframe子窗口方法 
<iframe name="myFrame" src="child.html"></iframe> 
myFrame.window.functionName(); 

//iframe子窗口調用父窗口方法 
parent.functionName();

② 用js互相調用iframe頁面內的js函數

一個html頁面,分成左右兩塊,左邊爲導航欄,右邊爲需要顯示的內容,代碼如下:

//左欄的代碼
<IFRAME frameBorder=0 id=frmTitleLeft name=framLeft src="left.html" style="HEIGHT: 100%; width:180px;">

內嵌鏈接到left.html

比如右欄中有一個函數right(),我要在左欄的鏈接中調用right()函數,該如何實現呢
1,首先leftframe是內嵌在容器頁index.html中的,因此需要先返回到index這一級別,並取得rightframe對象
var frames=window.parent.window.document.getElementById(“frameid”);
2,要能執行其頁面中的函數,必須要獲得window對象,這裏有一個重要的對象contentWindow,獲得這個對象,即可執行其中的函數了,如
frames.contentWindow.right();
以上代碼兼容IE6,Firefox3,chrome2.0,均成功通過測試,IE7沒試過,不過應該沒問題。
3.例如:
window.parent.document.getElementById(‘leftFrame’).contentWindow.JSMenu(‘MenuUl’+Sid);
window.parent.frames[“leftFrame”].JSMenu(‘MenuUl’+Sid);


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章