国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

如何編寫適合FireFox的對話框?

2020-07-27 13:31:35
字體:
來源:轉載
供稿:網友
在設計Blog操作流程的時候,計劃在添加頁面和修改頁面都用彈出對話框的方式。添加和修改結束時,點擊提交,對話框關閉,同時后面的列表窗口刷新。這樣就感覺在用Windows的界面程序一樣,界面友好性很好。 

但是在實際操作的時候發生了一個問題,IE的對話框技術,對FireFox是不支持的,怎么才能做到既支持IE又支持FireFox的對話框呢? 

還好,昨天在研究TinyMCE,里面有支持FireFox的對話框技術可以借鑒。 

我寫的打開對話框的方法: 
function popupDialog(url,width,height){ 
    //showx = event.screenX - event.offsetX - 4 - 10 ; // + deltaX;  這段代碼只對IE有效,已經不用了 
    //showy = event.screenY - event.offsetY -168; // + deltaY; 這段代碼只對IE有效,已經不用了 

        var x = parseInt(screen.width / 2.0) - (width / 2.0);  
    var y = parseInt(screen.height / 2.0) - (height / 2.0); 
        var isMSIE= (navigator.appName == "Microsoft Internet Explorer");  //判斷瀏覽器 

        if (isMSIE) {           
            retval = window.showModalDialog(url, window, "dialogWidth:"+width+"px; dialogHeight:"+height+"px; dialogLeft:"+x+"px; dialogTop:"+y+"px; status:no; directories:yes;scrollbars:no;Resizable=no; "  ); 
       } else { 
        var win = window.open(url, "mcePopup", "top=" + y + ",left=" + x + ",scrollbars=" + scrollbars + ",dialog=yes,modal=yes,width=" + width + ",height=" + height + ",resizable=no" ); 
        eval('try { win.resizeTo(width, height); } catch(e) { }'); 
        win.focus();             
    } 


在被打開的對話框里,我是用了上下分Frame的頁面,因為在 IE里,對話框是不可以提交的,但是分成Frame后,就可以提交了。 
在提交的按鈕上,加上這段代碼: 

  function doReload(){    
     var isMSIE= (navigator.appName == "Microsoft Internet Explorer"); 
     if (isMSIE){ 
         parent.dialogArguments.location.reload(); 
     }else{ 
         parent.opener.document.location.reload(); 
     }      
     top.close();     
  } 

兩種瀏覽器的打開對話框的方式不一樣 
IE:window.showModalDialog(url, window, "dialogWidth:300px; dialogHeight:300px; dialogLeft:200px; dialogTop:200px; status:no; directories:yes;scrollbars:no;Resizable=no; "  ); 
FireFox: window.open(url, "mcePopup", "top=200,left=200,scrollbars=no,dialog=yes,modal=yes,width=300,height=300,resizable=no" ); 

關閉窗口時: 
IE: parent.dialogArguments.location.reload(); 
FireFox:parent.opener.document.location.reload(); 

還有一個很重要的注意點。FireFox好像不支持對話框的window.close(); 
所以最后使用的關閉窗口用的是 top.close();  這個IE、FireFox都支持。 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 松桃| 咸阳市| 北海市| 新乡县| 陕西省| 巴林右旗| 陇南市| 宜昌市| 新密市| 葵青区| 右玉县| 赤峰市| 晋江市| 梁山县| 宜都市| 赞皇县| 玛纳斯县| 西乌珠穆沁旗| 翁源县| 呼和浩特市| 惠来县| 海林市| 长宁县| 绥江县| 兴隆县| 垫江县| 寿宁县| 普格县| 元氏县| 鄢陵县| 泗水县| 南康市| 桐城市| 固镇县| 漳平市| 长治县| 子长县| 观塘区| 镇安县| 恩施市| 阆中市|