1

设置属性时有什么方法可以防止触发onscroll事件?scrollTop

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

谢谢。

4

1 回答 1

0

这段代码有点骇人听闻,但它完成了工作:

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 运行在单个线程上,这意味着它们不会同时运行。因此,注释掉的锁定功能是无用的。如果你只是想同步滚动,上面的代码应该可以正常工作,但老实说我不太确定如何从那里开始。

于 2012-08-24T00:05:31.243 回答