用于触摸设备的Javascript拖放

IT技术 javascript jquery jquery-ui touch
2021-01-27 11:17:49

我正在寻找适用于触摸设备的拖放插件。

我想要与jQuery UI 插件类似的功能,它允许“放置”元素。

插件jqtouch支持拖动操作,但没有落下。

是仅支持 iPhone/iPad 的拖放。

任何人都可以指点我在 android/ios 上运行的拖放插件的方向吗?

...或者可以更新 jqtouch 插件以获得可删除性,它已经在 Andriod 和 IOS 上运行。

谢谢!

5个回答

您可以使用 Jquery UI 进行拖放以及将鼠标事件转换为您需要的触摸的附加库,我推荐的库是https://github.com/furf/jquery-ui-touch-punch,使用这是您从 Jquery UI 拖放应该适用于触摸设备

或者您可以使用我正在使用的这段代码,它还可以将鼠标事件转换为触摸,并且它的工作原理就像魔术一样。

function touchHandler(event) {
    var touch = event.changedTouches[0];

    var simulatedEvent = document.createEvent("MouseEvent");
        simulatedEvent.initMouseEvent({
        touchstart: "mousedown",
        touchmove: "mousemove",
        touchend: "mouseup"
    }[event.type], true, true, window, 1,
        touch.screenX, touch.screenY,
        touch.clientX, touch.clientY, false,
        false, false, false, 0, null);

    touch.target.dispatchEvent(simulatedEvent);
    event.preventDefault();
}

function init() {
    document.addEventListener("touchstart", touchHandler, true);
    document.addEventListener("touchmove", touchHandler, true);
    document.addEventListener("touchend", touchHandler, true);
    document.addEventListener("touchcancel", touchHandler, true);
}

在你的 document.ready 中调用 init() 函数

这里找到的代码

@JohnLandheer 我通过将事件侦听器仅附加到我想要可拖动的对象来解决这个问题, document.getElementById('draggableContainer').addEventListener(...
2021-03-27 11:17:49
谢谢,在我的 Android 设备上,现在可以拖动东西了。但是,当我点击它时,点击事件不再被触发。任何想法如何解决这个问题?
2021-03-30 11:17:49
触控打孔很棒。其中之一是“它只是有效”的东西。唉,它不支持双触摸...我很想看到。
2021-04-08 11:17:49
注意:由于为整个文档注册了事件侦听器,因此该解决方案还禁用了我的 Nexus S 上的滚动...
2021-04-10 11:17:49
感谢分享这个。但是,您应该感谢您发布的代码的原作者。 ross.posterous.com/2008/08/19/iphone-touch-events-in-javascript
2021-04-10 11:17:49

对于任何希望使用它并保留“点击”功能的人(正如 John Landheer 在他的评论中提到的),您只需进行一些修改即可:

添加几个全局变量:

var clickms = 100;
var lastTouchDown = -1;

然后把原来的switch语句修改成这样:

var d = new Date();
switch(event.type)
{
    case "touchstart": type = "mousedown"; lastTouchDown = d.getTime(); break;
    case "touchmove": type="mousemove"; lastTouchDown = -1; break;        
    case "touchend": if(lastTouchDown > -1 && (d.getTime() - lastTouchDown) < clickms){lastTouchDown = -1; type="click"; break;} type="mouseup"; break;
    default: return;
}

您可能想根据自己的喜好调整“clickms”。基本上它只是在观察“touchstart”,然后是“touchend”来模拟点击。

可以在此处找到使上述代码与单击事件一起工作的更新答案:stackoverflow.com/questions/28218888/...
2021-03-18 11:17:49
@ChakoDesai - 如果没有看到您的代码,我无法确定。您可能想为此提出一个新问题。
2021-04-05 11:17:49
@ChakoDesai - 自从我写下我的回复以来,答案中的代码已被大量编辑。查看stackoverflow.com/posts/6362527/revisions,查看2011年6月30日的代码;基于那个版本,我的回答会更有意义。
2021-04-06 11:17:49
@EZ Hart - 你能告诉我把你的代码放在上面给定代码的什么地方以启用点击事件吗???
2021-04-07 11:17:49
@EZ Hart - 我已经从给定的 url 更新了我的代码。但是为什么有时click有效有时无效???
2021-04-08 11:17:49

感谢以上代码!- 我尝试了几种选择,这就是票。我遇到了问题, preventDefault 阻止在 ipad 上滚动 - 我现在正在测试可拖动的项目,到目前为止效果很好。

if (event.target.id == 'draggable_item' ) {
    event.preventDefault();
}
你在 Windows Phone 上测试过吗?或者除了 iPhone 之外的任何东西?从过去的经验来看,这似乎在 iPhone/iPad 上工作得很好,但在其他设备上效果不佳,特别是在 Windows Phone 上。
2021-03-27 11:17:49

我有与gregpress answer相同的解决方案,但我的可拖动项目使用了一个类而不是一个 id。它似乎工作。

var $target = $(event.target);  
if( $target.hasClass('draggable') ) {  
    event.preventDefault();  
}
@bPratik 除非他希望答案提供更好的格式——而且他提供了整个代码示例的事实确实保证了一个单独的答案。虽然应该留下评论链接到他的答案......
2021-03-19 11:17:49
您只是使用了不同的选择器这一事实并不能保证是一个单独的答案,而是您应该对@gregpress 的答案发表评论。
2021-03-29 11:17:49

我知道的旧线程......

@ryuutatsuo 的答案的问题在于它还会阻止任何输入或其他必须对“点击”做出react的元素(例如输入),所以我写了这个解决方案。该解决方案使得在任何触摸设备(或计算机)上使用基于 mousedown、mousemove 和 mouseup 事件的任何现有拖放库成为可能。这也是一个跨浏览器的解决方案。

我已经在多种设备上进行了测试,它运行速度很快(结合 ThreeDubMedia 的拖放功能(另见http://threedubmedia.com/code/event/drag))。它是一个 jQuery 解决方案,因此您只能将它与 jQuery 库一起使用。为此使用了jQuery 1.5.1,因为一些较新的函数在 IE9 及更高版本中无法正常工作(未使用较新版本的 jQuery 进行测试)。

向事件添加任何拖放操作之前,您必须先调用此函数

simulateTouchEvents(<object>);

您还可以使用以下语法阻止所有组件/子组件的输入或加速事件处理:

simulateTouchEvents(<object>, true); // ignore events on childs

这是我写的代码。我使用了一些不错的技巧来加速评估事物(见代码)。

function simulateTouchEvents(oo,bIgnoreChilds)
{
 if( !$(oo)[0] )
  { return false; }

 if( !window.__touchTypes )
 {
   window.__touchTypes  = {touchstart:'mousedown',touchmove:'mousemove',touchend:'mouseup'};
   window.__touchInputs = {INPUT:1,TEXTAREA:1,SELECT:1,OPTION:1,'input':1,'textarea':1,'select':1,'option':1};
 }

$(oo).bind('touchstart touchmove touchend', function(ev)
{
    var bSame = (ev.target == this);
    if( bIgnoreChilds && !bSame )
     { return; }

    var b = (!bSame && ev.target.__ajqmeclk), // Get if object is already tested or input type
        e = ev.originalEvent;
    if( b === true || !e.touches || e.touches.length > 1 || !window.__touchTypes[e.type]  )
     { return; } //allow multi-touch gestures to work

    var oEv = ( !bSame && typeof b != 'boolean')?$(ev.target).data('events'):false,
        b = (!bSame)?(ev.target.__ajqmeclk = oEv?(oEv['click'] || oEv['mousedown'] || oEv['mouseup'] || oEv['mousemove']):false ):false;

    if( b || window.__touchInputs[ev.target.tagName] )
     { return; } //allow default clicks to work (and on inputs)

    // https://developer.mozilla.org/en/DOM/event.initMouseEvent for API
    var touch = e.changedTouches[0], newEvent = document.createEvent("MouseEvent");
    newEvent.initMouseEvent(window.__touchTypes[e.type], true, true, window, 1,
            touch.screenX, touch.screenY,
            touch.clientX, touch.clientY, false,
            false, false, false, 0, null);

    touch.target.dispatchEvent(newEvent);
    e.preventDefault();
    ev.stopImmediatePropagation();
    ev.stopPropagation();
    ev.preventDefault();
});
 return true;
}; 

它的作用:首先,它将单个触摸事件转换为鼠标事件。它检查事件是否由必须拖动的元素上/中的元素引起。如果它是输入元素,如 input、textarea 等,它会跳过翻译,或者如果附加了标准鼠标事件,它也会跳过翻译。

结果:可拖动元素上的每个元素仍在工作。

快乐编码,greetz,Erwin Haantjes

使用threedubmedia.com/code/event/drag并禁用元素的x 或y 移动。当您使用本文中的代码时,您可以“滚动”滚动条。但是要知道为什么要这样做,因为手机上的页面已经有了滚动条。不明白你想用它做什么。成功!
2021-03-24 11:17:49
你能看看我的另一个问题链接???
2021-04-02 11:17:49
我应该传入哪个对象simulateTouchEvents(<object>, true);???
2021-04-03 11:17:49
例如:simulateTouchEvents( $('#yourid; ), true ); 或模拟TouchEvents( document.getElementById('yourid') , true ); 等等
2021-04-04 11:17:49
我必须添加列的拖放和滚动。当我打开 中的touch事件时chrome,我无法滚动表格。甚至在手机上也不行。
2021-04-09 11:17:49