如果在母視窗要用 window.showModalDialog() 來開啟子視窗的話,
就不能在子視窗使用 window.opener 屬性來存取母視窗 (文法很怪,但我不知道怎麼用文字描述比較好... )
我只想到下面這個解法,您參考看看。
首先,showModalDialog() 的用法如下 (from MSDN):
由上得知這個 method 共有三個 input 參數,分別是 sURL, vArguments 與 sFeature,除了 sURL 為目標網頁必須填寫之外,後兩個皆非必要參數。
我的想法是,您在母視窗要使用 showModalDialog() 來打開一個子視窗時,將準備接收值的物件 (myObj) 帶進 vArguments,子視窗只要取出該物件即取得母視窗中 myObj 的參照
這樣一來,您就可以直接對該物件進行操作,就跟您直接在母視窗中操作 myObj 是一樣的。
呃,上面的敘述好像還是很難懂... 我附上兩個 html 來舉例好了...
請分別將兩段程式存檔,若檔名不是 AA.htm 與 BB.htm 的話請自行修改相關名稱。
這是母視窗 AA.htm
接下來是子視窗 BB.htm
程式流程就是,由 AA.htm 打開 BB.htm,操作者在 BB.htm 輸入資料後按下送出鍵,該資料即顯示在 AA.htm 中。
幾個關鍵地方我都用紅色標起來了,您可以加以修改符合您的需求。
test_showModalDialog.rar (0.55k)
就不能在子視窗使用 window.opener 屬性來存取母視窗 (文法很怪,但我不知道怎麼用文字描述比較好... )
我只想到下面這個解法,您參考看看。
首先,showModalDialog() 的用法如下 (from MSDN):
vReturnValue = window.showModalDialog(sURL [, vArguments] [, sFeatures])
由上得知這個 method 共有三個 input 參數,分別是 sURL, vArguments 與 sFeature,除了 sURL 為目標網頁必須填寫之外,後兩個皆非必要參數。
我的想法是,您在母視窗要使用 showModalDialog() 來打開一個子視窗時,將準備接收值的物件 (myObj) 帶進 vArguments,子視窗只要取出該物件即取得母視窗中 myObj 的參照
這樣一來,您就可以直接對該物件進行操作,就跟您直接在母視窗中操作 myObj 是一樣的。
呃,上面的敘述好像還是很難懂... 我附上兩個 html 來舉例好了...
請分別將兩段程式存檔,若檔名不是 AA.htm 與 BB.htm 的話請自行修改相關名稱。
這是母視窗 AA.htm
<form id="getForm">
回傳值:<input type="text" id="getData" readOnly>
</form>
<input type="button" value="開啟" onClick="openWin()">
<script language="JavaScript">
function openWin()
{
var srcFile = "BB.htm"; //指定子視窗的位置與檔名
var winFeatures = "dialogHeight:300px; dialogLeft:200px;";
var obj = getForm; //將物件傳遞到新視窗中
window.showModalDialog(srcFile, obj, winFeatures);
}
</script>
接下來是子視窗 BB.htm
<form id="sendForm">
請輸入資料:<input type="text" id="writeData">
<input type="button" value="送出" onClick="send(sendForm.writeData.value);">
</form>
<script language="JavaScript">
function send(val)
{
//取得前一頁所傳過來的物件
var myObj = window.dialogArguments;
//賦值
myObj.getData.value = val;
//若不須將子視窗關閉,則註解掉下面這行。
window.close();
}
</script>
程式流程就是,由 AA.htm 打開 BB.htm,操作者在 BB.htm 輸入資料後按下送出鍵,該資料即顯示在 AA.htm 中。
幾個關鍵地方我都用紅色標起來了,您可以加以修改符合您的需求。
test_showModalDialog.rar (0.55k)