HTML5拖放。检测在哪里抓取元素

时间:2018-08-21 16:44:25

标签: javascript html drag-and-drop html5-draggable

我正在使用HTML 5拖放API,并实现可排序列表和自动滚动。对于某些功能,我希望能够检测到元素的哪一部分被抓住

这是插图

enter image description here

任何帮助将不胜感激,谢谢

1 个答案:

答案 0 :(得分:1)

您可以使用计算出的元素的padding + width和MouseEventoffsetX属性来计算所选区域。

yourElement.addEventListener('mousedown', function onDragStart(event){
  let width = parseInt(window.getComputedStyle(yourElement).getPropertyValue('width'));
  let padding = parseInt(window.getComputedStyle(yourElement).getPropertyValue('padding-left'));
  let position = event.offsetX;
  let middle = (width / 2) + padding;

  if (position <= middle) {
    console.log('left');
  } else {
    console.log('right');
  }
});

有关示例,请参见此jsfiddle:https://jsfiddle.net/c23Lu6gy/28/