【问题标题】: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>