时间:2021-05-18
在设计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都支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
为了得到更丰富的自定义对话框功能,于是用JQuery编写了一个对话框插件;只需简单地引用相关JavaScript就能得到丰富的自定义对话框功能。插件功能特点:允
1.Bootstrap模态对话框和简单使用x对话框标题对话框主体取消确定可以使用按钮或链接直接调用模态对话框,这是简单的用法:打开对话框打开对话框2.使用rem
对话框的性质分为模态对话框和非模态对话框:1.模态对话框:打开该对话框之后,在该对话框之外的一切操作都是被禁止的,要想进行其他操作,必须先关闭本对话框。js命令
常用的Dialog有确认对话框,单选按钮对话框,多选按钮对话框,复选按钮对话框另外还有自定义的对话框AlertDialog的常用方法setTitle:为对话框设
本文实现了PyQt5个各种弹出窗口:输入框、消息框、文件对话框、颜色对话框、字体对话框、自定义对话框其中,为了实现自定义对话框的返回值,使用了信号/槽本文基于w