在開發的時候,遇到了這樣一個問題,客戶填寫自己的收貨地址,可以新建,但同時也可以選擇之前填寫的,由於我們的客戶本身就是商戶,地址繁多,把它之前的地址簡單用個下拉框羅列出來顯然不合適,並且客戶要求能夠對地址通過姓名篩選,這樣,選擇地址就必須再開一個小窗來完成了,那麼,小窗中填寫的值怎麼回傳呢? js有 ...
在開發的時候,遇到了這樣一個問題,客戶填寫自己的收貨地址,可以新建,但同時也可以選擇之前填寫的,由於我們的客戶本身就是商戶,地址繁多,把它之前的地址簡單用個下拉框羅列出來顯然不合適,並且客戶要求能夠對地址通過姓名篩選,這樣,選擇地址就必須再開一個小窗來完成了,那麼,小窗中填寫的值怎麼回傳呢?
js有個方法showModalDialog在這種情況下用的就比較多了,其作用是打開一個模態視窗,什麼事模態視窗?就是打開後不能操作父視窗,只有子視窗操作完了,關閉了,才可以繼續父視窗的動作。回到最開始的問題的話,就是給一個地址選擇入口,點擊觸發事件btn_click()。
父視窗JS
function btn_click() { var returnValue = window.showModalDialog('chooseAddr.aspx', window, 'dialogWidth=500px;dialogHeight=600px;status=no'); if (vReturnValue !== "" && vReturnValue !== undefined) { //處理子視窗的返回值 } }
子視窗中,在用戶完成篩選選擇等一系列動作以後,確定時,觸發事件returnVal()。
function returnVal() { var rtArr = new Array(); rtArr[0] = "test0"; rtArr[1] = "test1"; window.returnValue = retArr; window.close();//關掉子視窗,才能繼續父視窗的操作 }
這樣,就完成了父子視窗的“數據互動”,對了,父視窗怎麼向子視窗傳值呢,在本例下,我們需要知道操作用戶的id才能給他選擇自己之前填寫過的地址,只需在
window.showModalDialog的第一個參數,即打開的子視窗地址中加上參數?id=xxx,沒錯get方式傳過去就OK了。