6

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

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

谢谢!

4

2 回答 2

3

试试这个, 把库中的onTouchMove fn 改成这个bxslider

        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);
            }

        }
    }
于 2013-02-11T05:44:15.890 回答
2

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

这些就是你要找的。

于 2013-11-21T18:43:40.427 回答