【问题标题】:Horizontal swipe gesture and vertical page scroll水平滑动手势和垂直页面滚动
【发布时间】:2013-11-22 02:43:40
【问题描述】:

我正在构建一个移动网站,并且我有一个图像幻灯片放映,允许水平滑动图像。我正在使用的 javascript 库是 bxslider。但是,如果触摸幻灯片并想要向上/向下滚动页面,则幻灯片会阻止垂直滚动,因此必须触摸网站的另一部分。

谁能告诉我如何保持垂直滚动启用(即不允许幻灯片阻止正常滚动?)

谢谢!

【问题讨论】:

标签: javascript jquery bxslider


【解决方案1】:

试试这个,把bxslider库中的onTouchMovefn改成这个

        var onTouchMove = function (e) {
        if (slider.settings.mode != 'fade') {
            var orig = e.originalEvent;
            var value = 0;
            // if horizontal, drag along x axis
            if (slider.settings.mode == 'horizontal')
            {   
                var hchange = orig.changedTouches[0].pageX - slider.touch.start.x;
                var vchange = orig.changedTouches[0].pageY - slider.touch.start.y;

                if(Math.abs(hchange)>20 && Math.abs(hchange)>Math.abs(vchange))
                {   
                    value = slider.touch.originalPos.left + hchange;
                    setPositionProperty(value, 'reset', 0);
                    e.preventDefault();
                }
                // if vertical, drag along y axis
            } else{
                e.preventDefault();
                var change = orig.changedTouches[0].pageY - slider.touch.start.y;
                value = slider.touch.originalPos.top + change;
                setPositionProperty(value, 'reset', 0);
            }

        }
    }

【讨论】:

    【解决方案2】:

    如果您进入 bxslider 网站的选项页面,请搜索 preventDefaultSwipeX 和 preventDefaultSwipeY

    这些就是你要找的。​​p>

    【讨论】: