【JavaScript】EasyUI框架的Dialog控件根据浏览器分辨率自动调节宽高

序:

  如果单独一个或几个Dialog控件修改成根据浏览器可视界面自动调整高、宽很容易仅仅是一个量变的过程,但如果大量页面都引入了Dialog控件,修改起来是一个很消耗体力的工作。所以接到任务后第一想法就是能不能使在“公共母板页”中设置一处而自动修改继承此母板页的子页面中的Dialog也实现此功能。

 

0x01:

  有了思路后第一部就是查找EasyUI的API,然后没有发现什么可用的事件。未果。

 

0x02:

  有时换一种思路便可豁然开朗。EasyUI框架通过插入新的DOM元素而取缔原有的DOM,这个时候便会触发DOM元素的变更事件。所以第一个切入点就是找到事件。很显然“DOMNodeInserted”满足这个需求(PS:缺点就是每变更一个DOM元素都会触发此事件,不知会不会对客户端性能造成多大的影响,但从实验结果来看并没有拖慢Dialog的显示)。

  有了事件后就需要找到触发此事件的“主角”,也就是那个Dialog触发的。通过审核元素可以发现$('.panel.window:visible')此对象便是Dialog,e.currentTarget则是这个Dialog的DOM对象。所以在此事件中判断显示的Dialog是否大于0($('.panel.window:visible').length > 0),如果大于则用当前浏览器可视高,宽大于此Dialog的高、宽则进行设置。设置后还需要对位置进行移动。这些就可以简单批量处理Dialog高度自动调整了。无需每个Dialog单独进行设置了

 1 $(document).ready(function () {
 2     $('.panel.window').bind('DOMNodeInserted', function (e) {
 3         //var vHeight = $(window.parent).height();
 4         var vHeight = window.innerHeight;
 5         var vWidth = window.innerWidth;
 6 
 7         if ($('.panel.window:visible').length > 0) {
 8             var t = $(e.currentTarget).find('.easyui-dialog.panel-body.panel-body-noborder.window-body');
 9             var vDialogHeight = $('.panel.window:visible').css('height');
10             var vDialogWidth = $('.panel.window:visible').css('width');
11 
12             vDialogHeight = parseInt(vDialogHeight.replace('px', '')) + 50;
13             vDialogWidth = parseInt(vDialogWidth.replace('px', ''));
14             /* 如果Dialog高度大于等于当前可视高度,则设置Dialog距离上边距50px */
15             if (vHeight <= vDialogHeight) {
16                 t.dialog('resize', {
17                     height: vHeight - 100
18                 });
19             }
20             /* 如果Dialog宽度大于当前可视宽度,则设置Dialog距离左边距15px否则设置左右居中 */
21             if (vWidth <= vDialogWidth) {
22                 t.dialog('move', { left: 15 });
23             } else {
24                 t.dialog('move', { left: (vWidth - vDialogWidth) / 2 });
25             }
26             /* 设置Dialog垂直居中 */
27             t.dialog('move', { top: (vHeight - vDialogHeight + 50) / 2 });
28         }
29     });
30 });
Dialog Code

 

转载于:https://www.cnblogs.com/MangoCai/p/5614371.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值