这个问题困扰我好久了.终于找到了解决方案,非常感谢作者!

在设计Blog操作流程的时候,计划在添加页面和修改页面都用弹出对话框的方式。添加和修改结束时,点击提交,对话框关闭,同时后面的列表窗口刷新。这样就感觉在用Windows的界面程序一样,界面友好性很好。

但是在实际操作的时候发生了一个问题,IE的对话框技术,对FireFox是不支持的,怎么才能做到既支持IE又支持FireFox的对话框呢?

还好,昨天在研究TinyMCE,里面有支持FireFox的对话框技术可以借鉴。

我写的打开对话框的方法:
functionpopupDialog(url,width,height){
//showx=event.screenX-event.offsetX-4-10;//+deltaX;这段代码只对IE有效,已经不用了
//showy=event.screenY-event.offsetY-168;//+deltaY;这段代码只对IE有效,已经不用了

varx=parseInt(screen.width/2.0)-(width/2.0);
vary=parseInt(screen.height/2.0)-(height/2.0);
varisMSIE=(navigator.appName=="MicrosoftInternetExplorer");//判断浏览器

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{
varwin=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后,就可以提交了。
在提交的按钮上,加上这段代码:

functiondoReload(){
varisMSIE=(navigator.appName=="MicrosoftInternetExplorer");
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都支持。

更多相关文章

  1. 有没有办法阻止使用类似Firebug的工具在页面中编辑HTML和CSS内容
  2. 与同一页面上的两个jquery datepickers冲突
  3. 在Servlet和HTML页面之间处理函数调用和数据传输的最佳方法是什
  4. iframe操作、调用父页面元素或js函数
  5. 图片在页面内随意飘动,遇到边界还会反弹
  6. js点击button按钮跳转到另一个新页面
  7. 当页面上有多个按钮时,按钮样式在页面加载上有厚的边框
  8. 调用另一个html页面后,选择列表值不会保持不变
  9. JavaScript实际应用:父子页面交互

随机推荐

  1. go-carbon1.2.4发布了!新增系列时间比较方
  2. 你知道go程序的基本要素吗
  3. Go语言有没有优势?
  4. 如何使用golang的pprof包对程序进行性能
  5. 关于Golang 指针理解
  6. go语言导包时“.”和“_”的区别是什么?
  7. 详解Golang数组的传递
  8. 分享golang实现文件传输小demo
  9. go语言中run与build命令的区别是什么?
  10. 解决GO语言安装air框架时遇到go: inconsi