首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jquery -当到达容器时调整元素的大小

jquery -当到达容器时调整元素的大小
EN

Stack Overflow用户
提问于 2009-09-08 07:17:59
回答 1查看 2.5K关注 0票数 1

我有一个标准的div,在它的父级中设置为拖动和调整大小。我需要能够调整div的大小,因为它被拖到它的父级中。我只需要当它垂直拖动到底部时才会发生这种情况,所以我将其设置为:

代码语言:javascript
复制
$("#draggable").draggable({
    drag: function(event, ui) { AtBottom(); },
    axis:'y', containment:'parent'
});

然后我计算可拖动元素和它的容器的底部位置(减去偏移量),当它更大时重新调整它的大小。

代码语言:javascript
复制
function AtBottom(){

    var Cpos = $('#Container').position();
    var cheight = $('#Container').height();
    var Boundry =  Cpos.top+cheight;

    var pos = $("#draggable").position();
    var height = $("#draggable").height();
    var bottom = pos.top+height+10; /*10 as offset */

    if(bottom>Boundry){

        $("#draggable").height((height-10));

    }

}

似乎jquery在整个拖动过程中存储了元素属性,并且不会重新计算它们,这对性能是有意义的,但并不允许它以我希望的方式工作,否则它就会像->那样工作。每次拖动时,高度都会减少10。

有没有办法强制Jquery重新计算位置?->我已经试过启用/禁用了..

EN

回答 1

Stack Overflow用户

发布于 2010-09-29 05:27:37

我不得不做一些听起来像你正在做的事情,那就是基于可拖动区域比容器大的情况下创建一个约束(就像一个可拖动的地图)。我编辑了jquery-ui.js以执行以下操作,类似于容器,但称为约束。

在你的代码中设置它,就像你控制它一样:

代码语言:javascript
复制
$("#draggable").draggable({
    axis: 'y',
    constraint: 'parent'
});

第731行:

代码语言:javascript
复制
constraint: false,

第849行:

代码语言:javascript
复制
//Set a constraint if given in the options
if(o.constraint)
  this._setConstraint();

1071行:

代码语言:javascript
复制
  _setConstraint: function() {

    var o = this.options;
    if(o.constraint == 'parent') o.constraint = this.helper[0].parentNode;
    if(o.constraint == 'document' || o.constraint == 'window') this.constraint = [
      0 - this.offset.relative.left - this.offset.parent.left,
      0 - this.offset.relative.top - this.offset.parent.top,
      $(o.constraint == 'document' ? document : window).width() - this.helperProportions.width - this.margins.left,
      ($(o.constraint == 'document' ? document : window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height - this.margins.top
    ];

    if(!(/^(document|window|parent)$/).test(o.constraint) && o.constraint.constructor != Array) {
      var ce = $(o.constraint)[0]; if(!ce) return;
      var co = $(o.constraint).offset();
      var over = ($(ce).css("overflow") != 'hidden');

      this.constraint = [
        co.left + (parseInt($(ce).css("borderLeftWidth"),10) || 0) + (parseInt($(ce).css("paddingLeft"),10) || 0) - this.margins.left,
        co.top + (parseInt($(ce).css("borderTopWidth"),10) || 0) + (parseInt($(ce).css("paddingTop"),10) || 0) - this.margins.top,
        co.left+(over ? Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css("borderLeftWidth"),10) || 0) - (parseInt($(ce).css("paddingRight"),10) || 0) - this.helperProportions.width - this.margins.left,
        co.top+(over ? Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css("borderTopWidth"),10) || 0) - (parseInt($(ce).css("paddingBottom"),10) || 0) - this.helperProportions.height - this.margins.top
      ];
    } else if(o.constraint.constructor == Array) {
      this.constraint = o.constraint;
    }

  },

第1142行,在_generatePosition函数中:

代码语言:javascript
复制
  if(this.constraint) {
    if(event.pageX - this.offset.click.left > this.constraint[0]) pageX = this.constraint[0] + this.offset.click.left;
    if(event.pageY - this.offset.click.top > this.constraint[1]) pageY = this.constraint[1] + this.offset.click.top;
    if(event.pageX - this.offset.click.left < this.constraint[2]) pageX = this.constraint[2] + this.offset.click.left;
    if(event.pageY - this.offset.click.top < this.constraint[3]) pageY = this.constraint[3] + this.offset.click.top;
  }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1392456

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档