我正在尝试创建一个拖放调整大小的函数,我遇到了问题。该脚本不会立即对鼠标光标方向的变化作出反应。如果我按住按钮并向右移动光标,然后向左移动,它只会暂时增加对象的大小。 demo
使用Javascript:
var re_dragging = false, re_om_x, re_om_y, re_o_x, re_o_y, re_n_x, re_n_y;
function resize(resize_btn){
resize_btn.mousedown(function(e){
e.preventDefault();
e.stopPropagation();
re_dragging = true;
re_om_x = e.pageX;
re_om_y = e.pageY;// origin mouse postion
target_wp = $(e.target).closest('.draggable_wp').find('.draggable_el');
});
$(document).mousemove(function(e){
if(re_dragging){
target_wp.width((e.pageX - re_om_x) + target_wp.width());
}
});
$(document).mouseup(function(e){
re_dragging = false;
});
};
var resize_btn = $('.draggable_btn_resize');
resize(resize_btn);
HTML:
<div class="draggable_wp">
<div class="wp_img">
<img src=""class="draggable_el">
</div>
<div class="btn">
<div class="draggable_btn_resize"></div>
</div>
</div>
答案 0 :(得分:1)
使用re_om_x
重置宽度后,您需要更新re_om_x = e.pageX;
。
我添加了一个新变量width
,因为在target_wp.width((e.pageX - re_om_x) + target_wp.width());
中,target_wp.width()
会带来偏差,它总是会得到一个int。
我重写mousemove
如下:
$(document).mousemove(function (e) {
if (re_dragging) {
target_wp.width((e.pageX - re_om_x) + width);
width = (e.pageX - re_om_x) + width
re_om_x = e.pageX;
}
});
答案 1 :(得分:-1)
为简单起见,请参阅jQuery UI函数.resizable()。请记住,您需要将jqueryui .css和.js脚本添加到您的页面。然后你只需要打电话
$("#some_div_to_resize").resizable();