1

我正在使用 jquery 循环单词。自然,单词大小会发生变化,导致其旁边的非动画文本移位。有没有办法平滑这种位置变化?

我有什么:http: //jsfiddle.net/tWm36/121/

我想要实现的目标:https ://gumroad.com/

看看文本如何平滑地移动以适应循环中的单词,而不是突然移动?

<div>
<span id="changerificwordspanid">awesome</span>
 <span>This is so</span>

(function(){
var words = [
    'awesome',
    'incredible',
    'cool',
    'fantastic'
    ], i = 0;
setInterval(function(){
    $('#changerificwordspanid').fadeOut(function(){
        $(this).html(words[i=(i+1)%words.length]).fadeIn();
    });
}, 2000);

})();
4

1 回答 1

1

试试这样的!

<div> 
   <div id='words' style='visibility:hidden'>
       <span>awesome</span>
       <span>incredible</span>
       <span>cool</span>
       <span>fantastic</span>
   </div>

   <span id="changerificwordspanid" style='overflow-x:hidden'>awesome</span>
   <span>This is so</span>
</div>

我创建了包含文本的隐藏跨度。这使您可以获取浏览器计算的宽度。当我们淡入文本时,我们将对显示的跨度的宽度进行动画处理。设置overflow-x:hidden显示的跨度很重要,因为它允许宽度小于文本的宽度。使用 fadeOut() 并不完全正确,因为我们不想在任何时候设置 display:none,因为这会导致生涩的行为。所以只需像这样使用 animate() :

(function () {
    var words = $('#words span').map(function(i, obj) { return { width: $(obj).width() + 'px', text: $(obj).html() } });

    var i = 0;
    setInterval(function () {
        $('#changerificwordspanid').animate({ opacity: 0.0, width: words[i].width }, 
                                            400, function () {
            word = words[i = (i + 1) % words.length];
            $(this).html(word.text);
            $(this).animate({ opacity: 1.0, width: word.width });
        });
    }, 2000);

})();
于 2013-10-20T16:45:54.070 回答