设置onscroll
属性时,有没有办法防止触发scrollTop
事件?
var a = $(".elem");
a.scrollTop(100); // will fire onScroll
感谢。
答案 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在单个线程上运行,这意味着它们不会同时运行。因此注释掉的锁定功能是无用的。如果您只是尝试同步滚动,上面的代码应该可以正常工作,但我真的不太确定如何从那里开始。