我正在使用jQuery UI的draggables和 droppables功能。为了使其在触摸设备上起作用,我正在使用jQuery UI Touch Punch。
我有一系列没有太多空间的可拖动元素。在触摸设备上,我发现浏览列表的唯一方法是使用拖动元素周围很窄的空间,这不太用户友好。我考虑添加向上和向下滚动的按钮,但我认为对于习惯于通过轻扫来滚动的用户来说,这可能感觉陌生和笨重。最终,我采取了一种hacky的解决方法,但它有两个问题:
在滑动开始滚动之前需要花费一些时间,这可能会给人们留下网站滞后的错误印象。
没有动力学的滚动效果,所以滚动起来比平常更费劲。
我的问题
是否可以改进我的代码以解决以上两个问题,或者我应该采取完全不同的方法来解决这个问题?
代码
HTML
<p>Drag the colored squares into the gray area on the right.</p>
<ul>
<li><span class="red"></span></li>
<li><span class="orange"></span></li>
<li><span class="yellow"></span></li>
<li><span class="green"></span></li>
<li><span class="blue"></span></li>
<li><span class="purple"></span></li>
<li><span class="red"></span></li>
<li><span class="orange"></span></li>
<li><span class="yellow"></span></li>
<li><span class="green"></span></li>
<li><span class="blue"></span></li>
<li><span class="purple"></span></li>
<li><span class="red"></span></li>
<li><span class="orange"></span></li>
<li><span class="yellow"></span></li>
<li><span class="green"></span></li>
<li><span class="blue"></span></li>
<li><span class="purple"></span></li>
<li><span class="red"></span></li>
<li><span class="orange"></span></li>
<li><span class="yellow"></span></li>
<li><span class="green"></span></li>
<li><span class="blue"></span></li>
<li><span class="purple"></span></li>
</ul>
<div></div>
CSS
p {
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
margin-bottom: 10px;
}
ul, div {
float: left;
height: 440px;
background-color: #ccc;
border: 1px solid #000;
}
ul {
width: 127px;
overflow-y: scroll;
list-style: none;
}
li span {
margin: 9px auto;
}
span {
display: block;
width: 100px;
height: 100px;
border: 5px solid #000;
}
.red {
background-color: #f00;
}
.orange {
background-color: #ff8000;
}
.yellow {
background-color: #ff0;
}
.green {
background-color: #0f0;
}
.blue {
background-color: #00f;
}
.purple {
background-color: #f0f;
}
div {
width: 330px;
margin-left: 20px;
}
div span {
float: left;
}
JavaScript
// BEGIN: My attempt to fix the scrolling issue on touch devices
if ('ontouchstart' in document.documentElement) {
$('span').on('dragstart', function(e) {
if ($(this).hasClass('scroll')) {
e.preventDefault();
}
}).on('mousemove', function(e) {
if ($(this).hasClass('scroll')) {
$('ul').scrollTop(scroll_top_on_mousedown + mousedown_coords.pageY - e.pageY);
return false;
}
if (typeof(mousedown_coords) == 'object' && Math.max(
Math.abs(mousedown_coords.pageX - e.pageX),
Math.abs(mousedown_coords.pageY - e.pageY)
) >= 80
) {
if (e.pageX - mousedown_coords.pageX < 70) {
$(this).addClass('scroll');
}
}
}).on('mousedown', function(e) {
mousedown_coords = {
'pageX': e.pageX,
'pageY': e.pageY,
};
scroll_top_on_mousedown = $('ul').scrollTop();
}).on('touchend', function() {
$(this).trigger('mouseup'); // Android fix
delete window.mousedown_coords;
$('ul .scroll').removeClass('scroll');
});
}
// END: My attempt to fix the scrolling issue on touch devices
$('span').draggable({
distance: 90,
helper: 'clone',
containment: $('div')
});
$('div').droppable({
drop: function(event, ui) {
if ($(this).children('span').length == 12) {
$(this).empty();
}
$(this).append($(ui.draggable).clone());
}
});