1

我有一个用于触摸事件的 div 来扩展我正在构建的移动菜单。到目前为止,这是我的代码:

$("#" + obj.mobileButtonID).on({
    touchmove: function (e) {
        var touch = e.originalEvent.targetTouches[0],
        if (touch.pageX < 0) {
            e.stopPropagation();
        } else if (touch.pageX > 200) {
            e.stopPropagation();
        }
        $(this).css({ left: touch.pageX });
});

本质上,我想做的是touchmove在某些地方停止活动。说 div 是在某个pageX坐标之上还是在它之下。我觉得这很接近,但它的工作并不完全正确。每次touchmove事件触发时,它都会完全忽略我的条件并不断超出我布置的坐标。

有什么建议么?

4

1 回答 1

2

您在条件句中停止了事件的传播,但仍在应用左侧的 css 属性。如果您希望防止这种情况发生,请通过从条件返回来退出事件处理程序。传播用于将事件传播到层次结构DOM中更高的元素。DOM

于 2013-07-02T16:16:27.223 回答