防止滚动事件

时间:2012-08-23 22:42:37

标签: javascript jquery scroll

设置onscroll属性时,有没有办法防止触发scrollTop事件?

var a = $(".elem");
a.scrollTop(100); // will fire onScroll

感谢。

1 个答案:

答案 0 :(得分:0)

This code有点像hackish但它完成了工作:

var p1 = $('.one'), p2 = $('.two');
//var lock;
$('p').scroll(function() {
    //if (lock) return;
    //lock = true;
    var scrollTop = $(this).scrollTop();
    var other = $(this).hasClass('one') ? p2 : p1;
    other.scrollTop(300 - scrollTop);
    console.log('To:', 300 - scrollTop);
    //lock = false;
});​

我们似乎都做出的基本假设是事件将同时运行 ,但仔细观察后我们会发现Javascript在单个线程上运行,这意味着它们不会同时运行。因此注释掉的锁定功能是无用的。如果您只是尝试同步滚动,上面的代码应该可以正常工作,但我真的不太确定如何从那里开始。