1

我在这里找到了一个用户发布的用于无缝 jQuery 选框/自动收录器的代码。我已经将它修改为在滚动/滚动出时启动和停止,但是一旦用户滚动出去,它通常会滞后。它永远不会完全停止,但代码滚动的速度有时是其原始速度的 1/10。我已经加快了速度,因此更容易看到这种滞后。无论如何,如果有人知道如何解决这个问题,我将不胜感激。

jQuery

 $(function() {
  var marquee = $("#scroller");
  marquee.css({"overflow": "hidden", "width": "100%"});

  // wrap "My Text" with a span (IE doesn't like divs inline-block)
   marquee.wrapInner("<span>");
  marquee.find("span").css({ "width": "49%", "display": "inline-block", "text-align":"center", "padding-right":"1%" });
  marquee.append(marquee.find("span").clone()); // now there are two spans with "My Text"

   marquee.wrapInner("<div class='scrolling'>");
  marquee.find("div").css("width", "200%");

  var reset = function() {
       $(this).css({"margin-left":"0%"});
       $(this).animate({ "margin-left": "-100%" }, 500, 'linear', reset);
  };

  reset.call(marquee.find("div"));

  marquee.find("div").bind({
mouseenter: function () {
 $(this).stop();
 if($(this).css("margin-left") == "-"+$("#scroller").width() + "px") $(this).css("margin-left", "0%");
},
mouseleave: function() {
 $(this).stop().animate({ "margin-left": "-100%" }, 500, 'linear', reset);
}
});
});

HTML

<div id="scroller">
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
  Lorem ipsum dolor sit amet. &mdash; <a href="#">Username</a>&nbsp;&nbsp;&nbsp;
 </div>

谢谢,

格雷格

4

2 回答 2

1

很高兴您找到了足够的答复,但它似乎非常复杂,寻找类似解决方案的新用户无疑会感到困惑,除非他们对 javascript 相当了解。具有所有功能的类似 jQuery 插件;股票停止和开始回调,鼠标悬停自动暂停,让您清楚地阅读/点击正确的项目。以及完全控制方向和速度的无缝过渡。您可能想查看jQuery webTicker,这是一个免费使用的插件,所以请尽情享受。

于 2011-12-09T15:09:54.647 回答
0

似乎答案在于 JQuery 在 .clone() 和 .remove() 调用中管理内存的方式。有一个很好的讨论:

带有 DOM 删除的 jQuery 内存泄漏

更多详细信息和解决方法可在以下位置获得:

http://forum.jquery.com/topic/severe-memory-leak-with-clone

祝你好运!

于 2010-09-15T19:36:28.030 回答