参考地址

之前分别写过panel,dialog,window三个组件因为拖曳或者reSize造成组件越界而无法还原的问题,两篇文章分别针对拖曳和reSize给出了解决方案。不过根据朋友的反馈,reSize的解决方案拖曳的解决方案同时使用时存在效率低下的问题,个人也在进一步使用过程中发现了另外一些问题,共修正以下Bug:

  • 原生panel并无拖曳和缩放功能,且继承panel组件的上层组件太多,极容易出问题,故放弃对panel组件的支持。
  • onResize配合onMove使用时,性能低下,原因是由onResize触发的onMove内部死循环。已修正。
  • resize时,超越浏览器边界会造成缩放和拖动都不可用。通过增加了对offset的监控修正
  • IE8下,reSize超越浏览器边界后依旧会造成缩放和拖曳不可用,原因是IE8此时不影响onkeyup事件。已修正。
  • window,dioalg内部包含layout,datagrid组件时,resize高度小于一定值会造成性能低下。已修正。
  • 初始化时,如果页面不是最大化,onResize会把window和dialog高度自动变小。通过计数器修正。

实现代码:

最终综合两种方案,整理出代码:

  1. var ie = (function() {
  2. var undef, v = 3, div = document.createElement('div'), all = div
  3. .getElementsByTagName('i');
  4. while (div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->', all[0]);
  5. return v > 4 ? v : undef;
  6. }());
  7. /**
  8. * add by cgh
  9. * 针对panel window dialog三个组件调整大小时会超出父级元素的修正
  10. * 如果父级元素的overflow属性为hidden,则修复上下左右个方向
  11. * 如果父级元素的overflow属性为非hidden,则只修复上左两个方向
  12. * @param width
  13. * @param height
  14. * @returns
  15. */
  16. var easyuiPanelOnResize = function(width, height) {
  17. if (!$.data(this, 'window') && !$.data(this, 'dialog'))
  18. return;
  19. if (ie === 8) {
  20. var data = $.data(this, "window") || $.data(this, "dialog");
  21. if (data.pmask) {
  22. var masks = data.window.nextAll('.window-proxy-mask');
  23. if (masks.length > 1) {
  24. $(masks[1]).remove();
  25. masks[1] = null;
  26. }
  27. }
  28. }
  29. if ($(this).panel('options').maximized == true) {
  30. $(this).panel('options').fit = false;
  31. }
  32. $(this).panel('options').reSizing = true;
  33. if (!$(this).panel('options').reSizeNum) {
  34. $(this).panel('options').reSizeNum = 1;
  35. } else {
  36. $(this).panel('options').reSizeNum++;
  37. }
  38. var parentObj = $(this).panel('panel').parent();
  39. var left = $(this).panel('panel').position().left;
  40. var top = $(this).panel('panel').position().top;
  41. if ($(this).panel('panel').offset().left < 0) {
  42. $(this).panel('move', {
  43. left : 0
  44. });
  45. }
  46. if ($(this).panel('panel').offset().top < 0) {
  47. $(this).panel('move', {
  48. top : 0
  49. });
  50. }
  51. if (left < 0) {
  52. $(this).panel('move', {
  53. left : 0
  54. }).panel('resize', {
  55. width : width + left
  56. });
  57. }
  58. if (top < 0) {
  59. $(this).panel('move', {
  60. top : 0
  61. }).panel('resize', {
  62. height : height + top
  63. });
  64. }
  65. if (parentObj.css("overflow") == "hidden") {
  66. var inline = $.data(this, "window").options.inline;
  67. if (inline == false) {
  68. parentObj = $(window);
  69. }
  70. if ((width + left > parentObj.width())
  71. && $(this).panel('options').reSizeNum > 1) {
  72. $(this).panel('resize', {
  73. width : parentObj.width() - left
  74. });
  75. }
  76. if ((height + top > parentObj.height())
  77. && $(this).panel('options').reSizeNum > 1) {
  78. $(this).panel('resize', {
  79. height : parentObj.height() - top
  80. });
  81. }
  82. }
  83. $(this).panel('options').reSizing = false;
  84. };
  85. /**
  86. * add by cgh
  87. * 针对panel window dialog三个组件拖动时会超出父级元素的修正
  88. * 如果父级元素的overflow属性为hidden,则修复上下左右个方向
  89. * 如果父级元素的overflow属性为非hidden,则只修复上左两个方向
  90. * @param left
  91. * @param top
  92. * @returns
  93. */
  94. var easyuiPanelOnMove = function(left, top) {
  95. if ($(this).panel('options').reSizing)
  96. return;
  97. var parentObj = $(this).panel('panel').parent();
  98. var width = $(this).panel('options').width;
  99. var height = $(this).panel('options').height;
  100. var right = left + width;
  101. var buttom = top + height;
  102. var parentWidth = parentObj.width();
  103. var parentHeight = parentObj.height();
  104. if (left < 0) {
  105. $(this).panel('move', {
  106. left : 0
  107. });
  108. }
  109. if (top < 0) {
  110. $(this).panel('move', {
  111. top : 0
  112. });
  113. }
  114. if (parentObj.css("overflow") == "hidden") {
  115. var inline = $.data(this, "window").options.inline;
  116. if (inline == false) {
  117. parentObj = $(window);
  118. }
  119. if (left > parentObj.width() - width) {
  120. $(this).panel('move', {
  121. "left" : parentObj.width() - width
  122. });
  123. }
  124. if (top > parentObj.height() - height) {
  125. $(this).panel('move', {
  126. "top" : parentObj.height() - height
  127. });
  128. }
  129. }
  130. };
  131. $.fn.window.defaults.onResize = easyuiPanelOnResize;
  132. $.fn.dialog.defaults.onResize = easyuiPanelOnResize;
  133. $.fn.window.defaults.onMove = easyuiPanelOnMove;
  134. $.fn.dialog.defaults.onMove = easyuiPanelOnMove;

使用的时候,请在引入easyui的核心文件后,直接追加以上代码,注意不要写在document.ready里面。

到这里,panel,window,dialog等组件越界的问题就算是基本解决了。欢迎大家测试,即时反馈Bug。

效果演示:

http://www.easyui.info/easyui/demo/window/062.html

panel,dialog,window组件越界(超出范围)问题汇总的更多相关文章

  1. panel,dialog,window组件越界问题汇总

    之前分别写过panel,dialog,window三个组件因为拖曳或者reSize造成组件越界而无法还原的问题,两篇文章分别针对拖曳和reSize给出了解决方案.不过根据朋友的反馈,reSize的解决 ...

  2. 解决jqueryeasyUI dialog 弹出窗体超出浏览器,导致不能关闭的bug

    使用panel的onMove事件攻克了panel,dialog以及window组件在被拖动时,会超出浏览器边界而无法拖回的情况. 当窗体被拖出浏览器有边界时.$(document).width();会 ...

  3. jqueryeasyUI dialog 弹出窗口超出浏览器,导致不能关闭的bug解决方案

    jqueryeasyUI dialog 弹出窗口超出浏览器,导致不能关闭的bug解决方案 2014年8月30日 3233次浏览 相信很多前端朋友都用过jqueryeasyUI,jqueryeasyUI ...

  4. Dialog( 对话框) 组件

    一. 加载方式//class 加载方式<div class="easyui-dialog" title="My Dialog"style="wi ...

  5. 第二百零四节,jQuery EasyUI,Dialog(对话框)组件

    jQuery EasyUI,Dialog(对话框)组件 学习要点: 1.加载方式 2.属性列表 3.事件列表 4.方法列表 本节课重点了解EasyUI中Dialog(窗口)组件的使用方法,这个组件依赖 ...

  6. ExtJS学习之路第八步:Window组件

    一个专门Panel用作程序窗口.默认的,Window可以是浮动的(floated).可缩放(resizable)以及可拖动的(draggable).Window能够被最大化适应可视窗口,(restor ...

  7. EasyUI 关于IE使用window组件上传文件

    有时候IE会对使用window组件上传文件(第二次)不生效,解决方案是: 将该window每次打开的时候,使用: $('#adUploadWindow').window('refresh', 'pan ...

  8. Javascript - ExtJs - Window组件

    1.所有组件都可以放入window,此时子组件不需要配置renderTo,只需要将它们作为window的items子项即可. 2.items子项必须先创建,最后创建window,否则子项不会显示. 3 ...

  9. 无废话ExtJs 入门教程三[窗体:Window组件]

    无废话ExtJs 入门教程三[窗体:Window组件] extjs技术交流,欢迎加群(201926085) 1.代码如下: 1 <!DOCTYPE html PUBLIC "-//W3 ...

随机推荐

  1. 人脸检测:微软 VS Face++

    近些年国内的人脸技术已经得到了很大的发展,今天网上无意看到了微软和face++两家公司的人脸检测,Face++号称国际顶尖的技术,也用过他们的接口感觉确实很不错,而微软则不再话下了.于是想对比微软和F ...

  2. (转)Ext.Button点击事件的三种写法

    转自:http://maidini.blog.163.com/blog/static/377627042008111061844345/ ExtJs的写法太灵活了,现在收集了关于Button点击事件的 ...

  3. vc listview 大图标间距设置

    SendMessage(this.listViewChart.Handle,   LVM_SETICONSPACING,   0,   0x10000   *   140   +   130); 其中 ...

  4. koa2搭建服务器+使用mongoose链接mangodb

    使用node搭建服务器,用到了现在比较流行的框架koa. 1.初始化package.json npm init -y 2.安装koa2 npm i koa --save 3.搭建服务器 const K ...

  5. oracle全文索引的创建和使用

    整理一下我所遇到过的有关全文索引的问题吧 一.设置词法分析器 Oracle实现全文检索,其机制其实很简单.即通过Oracle专利的词法分析器(lexer),将文章中所有的表意单元(Oracle 称为  ...

  6. Python 日期和时间 —— datetime

    Python 日期和时间 —— datetime Python提供了多个内置模块用于操作日期时间,如calendar,time,datetime.calendar用于处理日历相关 :time提供的接口 ...

  7. SpringSecurity实现后台管理员登录(二)

    需求:login.ftl页面中登录成功后进入index.ftl页面中 一.pom.xml中添加json转换相关的包 <dependency> <groupId>com.fast ...

  8. Java GC、新生代、老年代

    堆内存 Java 中的堆是 JVM 所管理的最大的一块内存空间,主要用于存放各种类的实例对象.在 Java 中,堆被划分成两个不同的区域:新生代 ( Young ).老年代 ( Old ).新生代 ( ...

  9. NPOI导出Excel时出现错误“Maximum column number is 255”

    此错误并不是NPOI的问题,而是Excel的问题,原因是Excel的最大列255,所以导出的列超过255时就会出现此问题 但Excel2007以上并没有此问题,因为2007以上的列已经增加到16384 ...

  10. SSIS实践入门2:批量包的调度和SQLServer代理作业配置

    趁着上一篇文章的余温,我们继续研究一下SSIS中多个包如何调度,难道需要一个包一个包的配置调度程序吗?显然不是的,接下来我们就说一说在SSIS应用中如何批量的调度所有的作业,本文只讲述一个基本的逻辑过 ...