0

我下面的代码有点笨拙,所以我需要你的专业知识来解决这两个问题。我知道很多例子,但我想学一点,也有一个更干净的代码。

  1. 滑动时,DIV 项目不会并排显示。一个在另一个之下,这是错误的。
  2. 我可以增强 jQuery 代码以使其循环或更动态,使其看起来更专业。如果我有 100 个 DIV,那将无法处理。
  3. 它永远不应该停止。

谢谢

<html>
    <style>
    *           { margin: 0px; padding: 0px; }
    #cover      { width: 100%; height: 300px; background: #CCCCCC; }
    #cover div  { width: 100%; height: 200px; background: #FFFFFF; }
    .content    { text-align: center; }
    </style>
    <head>
        <link href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/themes/base/jquery-ui.css" rel="stylesheet" type="text/css"/>
        <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
        <script src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8/jquery-ui.min.js"></script>
        <script type="text/javascript">
            $(document).ready(function()
            {
                event.preventDefault();

                $('#slider_2').hide().delay(5000);
                $('#slider_3').hide().delay(10000);
                $('#slider_1').show('slide', { direction: 'left' }, 1000);
                $('#slider_1').delay(4000).hide('slide', { direction: 'left' }, 1000);
                $('#slider_2').show('slide', { direction: 'right' }, 1000);
                $('#slider_2').delay(4000).hide('slide', { direction: 'right' }, 1000);
                $('#slider_3').show('slide', { direction: 'left' }, 1000);
                $('#slider_3').delay(4000).hide('slide', { direction: 'left' }, 1000);
            });
        </script>
    </head>

    <body>
        <div id="cover">
            <div id="slider_1"><p class="content">SLIDER ONE</p></div>
            <div id="slider_2"><p class="content">SLIDER TWO</p></div>
            <div id="slider_3"><p class="content">SLIDER THREE</p></div>
        </div>
    </body>
</html>
4

1 回答 1

0

这些动画需要正确链接。一个元素的所有内容都需要出现在一个语句中:

$('#slider_1').show(...).delay(4000).hide(...);

否则 jQuery 可能会在第二个语句中用第二个链(延迟隐藏)覆盖第一个动画链(显示)。

于 2012-08-02T10:56:37.303 回答