zoukankan      html  css  js  c++  java
  • 關於showModalDialog回传值的問題

    如果在母視窗要用 window.showModalDialog() 來開啟子視窗的話,
    就不能在子視窗使用 window.opener 屬性來存取母視窗 (文法很怪,但我不知道怎麼用文字描述比較好... Tongue)

    我只想到下面這個解法,您參考看看。

    首先,showModalDialog() 的用法如下 (from MSDN):

    vReturnValue = window.showModalDialog(sURL [, vArguments] [, sFeatures])


    由上得知這個 method 共有三個 input 參數,分別是 sURL, vArguments 與 sFeature,除了 sURL 為目標網頁必須填寫之外,後兩個皆非必要參數。

    我的想法是,您在母視窗要使用 showModalDialog() 來打開一個子視窗時,將準備接收值的物件 (myObj) 帶進 vArguments,子視窗只要取出該物件即取得母視窗中 myObj 的參照
    這樣一來,您就可以直接對該物件進行操作,就跟您直接在母視窗中操作 myObj 是一樣的。

    呃,上面的敘述好像還是很難懂... Black Eye 我附上兩個 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)
  • 相关阅读:
    OD 实验(十三)
    第一个 Windows 界面程序
    C 语言
    C 语言
    OD 实验(十二)
    PowerShell 常用命令
    OD 实验(十一)
    OD 实验(十)
    redis
    memcached缓存系统
  • 原文地址:https://www.cnblogs.com/huqingyu/p/29972.html
Copyright © 2011-2022 走看看