【发布时间】:2011-08-24 17:35:03
【问题描述】:
我正在尝试从右到左滚动文本(实际上是列表元素)。
这是 HTML 代码
<div id="slider-txt">
<ul>
<li class="islide">text 1</li>
<li class="islide">text 2</li>
</ul>
</div>
我的 CSS
#slider-txt
{
position:relative;
width: 590px;
}
#slider-txt ul
{
list-style-type: none;
position: absolute;
margin: 0px;
padding: 0px;
}
#slider-txt ul li
{
text-align: right;
}
和 jQuery
var box = $('#slider-txt');
if (box.length == 0) {
return;
}
var ul = box.find('ul');
var li = $('#slider-txt').find('li');
var liWidth = box.width();
var ulWidth = liWidth * li.length;
li.css('width', liWidth);
ul.css('width', ulWidth);
li.css('display', 'inline-block');
var liElement = 0;
function slideNxt() {
liElement++;
if (liElement == li.length) {
liElement = 0;
}
var curLeftPos = ul.css('left').split('px')[0];
var newLeftPos = -(liElement * liWidth);
ul.animate({ left: newOffset + 'px' }, { duration: 'slow', easing: 'swing' });
}
setInterval(slideNxt, 2000);
上面的代码在循环中从右到左和从左到右摆动列表项。列表项上设置的 inline-block 属性似乎没有按预期工作(列表项显示在另一个下方)。此外,如果列表项开箱即用 (div#slider-txt) 宽度,我希望它被隐藏,这不会发生。
您能帮我解决这些问题吗?谢谢...
【问题讨论】:
-
使用 HTML 的
marquee
标签。 (笑) -
对不起哥们,但我想用 jQuery 来实现它,因为我会添加更多的效果。
标签: jquery css scroll jquery-animate right-to-left