Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 424|回复: 0

jquery easyui dialog Bug解决方案

[复制链接]
  • TA的每日心情
    奋斗
    4 天前
  • 签到天数: 802 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726006
    发表于 2021-6-1 12:46:19 | 显示全部楼层 |阅读模式

    最近一直都在用easyui前端框架来开发设计UI,但在使用Dialog时,发现如果页面内容比较多,就会出现问题,首先看一下我的原代码:

     <input type="button" value="确认预约" id="btnconfirm" onclick="javascript:openconfirmDlg();" />
    
        <div id="confirmd">  
            <p>请选择确认结果:</p>
            <p><input type="radio" value="True" id="rtrue" name="rresult" class="rresult" /><label for="rtrue">成功</label>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
            <input type="radio" value="False" id="rfalse" name="rresult" class="rresult" /><label for="rfalse">失败</label></p>
        </div>
         <script type="text/javascript">
             $("#confirmd").dialog({
                 title: '预约确认',
                 iconCls: 'icon-save', resizable: false, modal: true, closed: true,
                 width: 200, height: 200,
                 buttons: [{ text: '提 交', handler: function () {
                     alert("ok");
                 }
                 }, { text: '取 消', handler: function () {
                     $("#confirmd").dialog("close");
                 }
                 }]
             });
    
    
         function openconfirmDlg() {
             $("#confirmd").dialog("open");
         }
    
         </script>
     
    

    当点击【确认预约】按钮时,打开对话框,效果如下:

    可以看到几个问题,一是遮罩层没有全部盖住网页内容,二是对话框不见了,当然不是真的不见了,而是显示到了页面的上方,需要将滚动条拖回到项端方可见到,造成这样的原因很清楚,一是获取网页内容高度不正确,只是得到了window的高度(即可视高度),才会出现遮罩不完整,二是定位不正确,未能正确识别到scrollTop,造成对话框定位不准,针对这些问题,我做出了相应的改进,从而解决了该问题,下面是改进后的代码:

        <input type="button" value="确认预约" id="btnconfirm" onclick="javascript:openconfirmDlg();" />
    
        <div id="confirmd">  
            <p>请选择确认结果:</p>
            <p><input type="radio" value="True" id="rtrue" name="rresult" class="rresult" /><label for="rtrue">成功</label>
            &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
            <input type="radio" value="False" id="rfalse" name="rresult" class="rresult" /><label for="rfalse">失败</label></p>
        </div>
         <script type="text/javascript">
             $("#confirmd").dialog({
                 title: '预约确认',
                 iconCls: 'icon-save', resizable: false, modal: true, closed: true,
                 width: 200, height: 200,
                 buttons: [{ text: '提 交', handler: function () {
                     alert("ok");
                 }
                 }, { text: '取 消', handler: function () {
                     $("#confirmd").dialog("close");
                 }
                 }]
             });
    
    
         window.onscroll = function () {
             $("#confirmd").dialog("move", { top: $(document).scrollTop() + ($(window).height() - 200) * 0.5 }); 
         }
    
         function openconfirmDlg() {
             $("#confirmd").dialog("open");
             $("#confirmd").dialog("move", { top: $(document).scrollTop() + ($(window).height() - 200) * 0.5 });
             $(".window-mask").css({ height: $(document).height()});
         }
    
         </script>

    现在打开对话框就正常了,效果如下:

    即使滚动也能始终处在网页中间,效果如下:

    确保如上效果的关键代码是:

             $("#confirmd").dialog("move", { top: $(document).scrollTop() + ($(window).height() - 200) * 0.5 }); //移动到当前内容页面的中间
             $(".window-mask").css({ height: $(document).height()}); //调整遮罩层的高度为网页内容高度

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-11-15 12:58 , Processed in 1.142981 second(s), 28 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表