gpt4 book ai didi

javascript - 在缩放的 div 上拖动元素

转载 作者:数据小太阳 更新时间:2023-10-29 03:55:03 25 4
gpt4 key购买 nike

我试过使用 jquery 内置的可拖动功能,也试过使用自定义拖动功能但无济于事。两者都有各自的问题,我将尝试着重强调它们。

基本上,我试图允许拖动缩放的 div 容器上的元素。以下方法在小于 2 左右的缩放元素上正常。但如果你再高一点,我们就会发现一些问题。

如有任何帮助,我们将不胜感激。感谢您的宝贵时间。

HTML

<div id="container">
<div id="dragme">Hi</div>
</div>

方法一(Jquery可拖动函数)

我已经尝试了 jquery 可拖动功能,正如您在 jsfiddle 中看到的那样示例。

我在这个例子中发现的问题如下:

  • 最大的问题:可放置的容器在放大时不会改变。因此,如果该元素被拖动到不是其原始大小的一部分的缩放容器的一部分上,它将失败。
  • 当您点击拖动一个 div 时,它会传送到远离鼠标的一点点,这不是一个无缝拖动。

JS

var percent = 2.5;

$("#dragme").draggable({
zIndex: 3000,
appendTo: 'body',
helper: function (e, ui) {
var draggable_element = $(this),
width = draggable_element.css('width'),
height = draggable_element.css('height'),
text = draggable_element.text(),
fontsize = draggable_element.css('font-size'),
textalign = draggable_element.css('font-size');
return $('<div id="' + draggable_element.id + '" name="' + draggable_element.attr('name') + '" class="text">' + text + '</div>').css({
'position': 'absolute',
'text-align': textalign,
'background-color': "red",
'font-size': fontsize,
'line-height': height,
'width': width,
'height': height,
'transform': 'scale(' + percent + ')',
'-moz-transform': 'scale(' + percent + ')',
'-webkit-transform': 'scale(' + percent + ')',
'-ms-transform': 'scale(' + percent + ')'
});
},
start: function (e, ui) {
$(this).hide();
},
stop: function (e, ui) {
$(this).show();
}
});

$("#container").droppable({
drop: function (event, ui) {
var formBg = $(this),
x = ui.offset.left,
y = ui.offset.top,
drag_type = ui.draggable.attr('id');

var element_top = (y - formBg.offset().top - $(ui.draggable).height() * (percent - 1) / 2) / percent,
element_left = (x - formBg.offset().left - $(ui.draggable).width() * (percent - 1) / 2) / percent;

$(ui.draggable).css({
'top': element_top,
'left': element_left
});

}
});

方法二——自定义拖动功能

我试过使用自定义拖动功能,但在大约 2 比例后它无法使用。

  • jsfiddlescale(2) 上 - 看起来可拖动的 div 正在癫痫发作。
  • jsfiddlescale(2.5) 上 - 当您尝试拖动可拖动的 div 时它会飞走。

JS

(function ($) {
$.fn.drags = function (opt) {

opt = $.extend({
handle: "",
cursor: "move"
}, opt);

if (opt.handle === "") {
var $el = this;
} else {
var $parent = this;
var $el = this.find(opt.handle);
}

return $el.css('cursor', opt.cursor).on("mousedown", function (e) {
if (opt.handle === "") {
var $drag = $(this).addClass('draggable');
} else {
$(this).addClass('active-handle')
var $drag = $parent.addClass('draggable');
}

var
drg_h = $drag.outerHeight(),
drg_w = $drag.outerWidth(),
pos_y = $drag.offset().top + drg_h - e.pageY,
pos_x = $drag.offset().left + drg_w - e.pageX;

follow = function (e) {
$drag.offset({
top: e.pageY + pos_y - drg_h,
left: e.pageX + pos_x - drg_w
})
};

$(window).on("mousemove", follow).on("mouseup", function () {
$drag.removeClass('draggable');
$(window).off("mousemove", follow);
});

e.preventDefault(); // disable selection

}).on("mouseup", function () {
if (opt.handle === "") {
$(this).removeClass('draggable');
} else {
$(this).removeClass('active-handle');
$parent.removeClass('draggable');
}
});

}
})(jQuery);

$("#dragme").drags({}, function (e) {});

最佳答案

以下是我的一些发现,以确保在缩放容器上拖动适用于方法一。唯一需要注意的是,在任何这些操作发生之前,请确保您将 var percent 作为缩放百分比声明。

首先,在您的 javascript 顶部使用此代码。这将有助于确保可放置区域适用于 sacled 容器。

$.ui.ddmanager.prepareOffsets = function( t, event ) { var i, j, m = $.ui.ddmanager.droppables[ t.options.scope ] || [], type = event ? event.type : null, list = ( t.currentItem || t.element ).find( ":data(ui-droppable)" ).addBack(); droppablesLoop: for ( i = 0; i < m.length; i++ ) { if ( m[ i ].options.disabled || ( t && !m[ i ].accept.call( m[ i ].element[ 0 ], ( t.currentItem || t.element ) ) ) ) { continue; } for ( j = 0; j < list.length; j++ ) { if ( list[ j ] === m[ i ].element[ 0 ] ) { m[ i ].proportions().height = 0; continue droppablesLoop; }  } m[ i ].visible = m[ i ].element.css( "display" ) !== "none"; if ( !m[ i ].visible ) { continue; } if ( type === "mousedown" ) { m[ i ]._activate.call( m[ i ], event ); } m[ i ].offset = m[ i ].element.offset(); m[ i ].proportions({ width: m[ i ].element[ 0 ].offsetWidth * percent, height: m[ i ].element[ 0 ].offsetHeight * percent }); } };

这里有一些必要的函数来修复拖动,以便它在缩放的容器上工作。

function dragFix(event, ui) { var changeLeft = ui.position.left - ui.originalPosition.left, newLeft = ui.originalPosition.left + changeLeft / percent, changeTop = ui.position.top - ui.originalPosition.top, newTop = ui.originalPosition.top + changeTop / percent; ui.position.left = newLeft; ui.position.top = newTop; }

function startFix(event, ui) { ui.position.left = 0; ui.position.top = 0;  var element = $(this); }

如果你想让元素在缩放的容器上可以调整大小,你会需要这个。

function resizeFix(event, ui) { var changeWidth = ui.size.width - ui.originalSize.width, newWidth = ui.originalSize.width + changeWidth / percent, changeHeight = ui.size.height - ui.originalSize.height, newHeight = ui.originalSize.height + changeHeight / percent;  ui.size.width = newWidth; ui.size.height = newHeight; }

为了使元素可拖动,我使用了以下函数。

$("ELEMENT").resizable({ minWidth: - ($(this).width()) * 10, minHeight: - ($(this).height()) * 10, resize: resizeFix, start: startFix });
$("ELEMENT").draggable({ cursor: "move", start: startFix, drag: dragFix }); }

关于javascript - 在缩放的 div 上拖动元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28821880/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com