作家
登录

如何编写适合FireFox的对话框?

作者: 来源:www.28hudong.com 2013-03-30 09:03:19 阅读 我要评论

在设计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都支持。

  推荐阅读

  msxml3.dll 错误 ''800c0005''解决方案

在运用xmlhttp组件编写程序中,会碰到 "msxml3.dll 错误 '800c0005' 系统未找到指定的资源。" 这种错误,网上对这种错误的产生原因有很多钟解释,大体说是因为防火墙或UDP站口权限造成了,也说了相应的解决办法。其>>>详细阅读


本文标题:如何编写适合FireFox的对话框?

地址:http://www.17bianji.com/kaifa2/ASP/33197.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)