单击时水平显示动画幻灯片

时间:2011-05-25 12:56:13

标签: javascript jquery

Div id="content"需要更改内容。我有两个DIV s,某处使用id=1id=2生成,我希望div id="content"显示一个,  但是当我点击某个按钮更改另一个DIV上的内容时,但是使用平滑的水平动画,就像在图像库上左右滚动一样。如何用jQuery做到这一点?

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  </head>
  <body>
      <div id="content">
      </div>
  </body>
</html>

4 个答案:

答案 0 :(得分:4)

仅CSS示例based on this SO answer
它使用 CSS3 flex作为模板,使用transition作为漂亮的幻灯片效果:

*{box-sizing:border-box;}
html, body{height:100%; margin:0;}
body{
  font: 16px/1 sans-serif;
  color:#fff;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
nav ul{
  list-style:none;
  padding:0;
  margin:0;
  display: flex;
}
nav ul li{
  flex: 1;
}
nav ul li a{
  display: block;
  text-align:center;
  padding:24px;
  background:#0bf;
  color:#fff;
}
#pages{
  flex-grow: 1;
  display: flex;
  transition: 1s;
}
#pages section{
  overflow: auto;
  min-width: 100%;
  overflow-y: auto;
  padding: 0 32px;
  font-size: 40px;
}

.bg1{background:#0af;}
.bg2{background:#f0a;}
.bg3{background:#0fa;}

#home:target ~ #pages{
  transform: translateX(-0%);
}
#about:target ~ #pages{
  transform: translateX(-100%);
}
#contact:target ~ #pages{
  transform: translateX(-200%);
}
<nav>
  <ul>
    <li><a href="#home" class="bg1">HOME</a></li>
    <li><a href="#about" class="bg2">ABOUT</a></li>
    <li><a href="#contact" class="bg3">CONTACT</a></li>
  </ul>
</nav>

<!-- dummy anchor targets -->
<i class="target" id="home"></i>
<i class="target" id="about"></i>
<i class="target" id="contact"></i>

<div id="pages">
  <section class="bg1">
    <h1>WELCOME</h1>
    <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Iure repellendus impedit, fugiat nostrum totam possimus perferendis aut explicabo, perspiciatis veritatis dolorem recusandae ut ratione similique magnam ex tenetur qui doloribus.</p>
  </section>  
  <section class="bg2">
    <h1>ABOUT</h1>
    <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Doloribus praesentium ipsum esse autem quisquam earum accusantium cumque, ipsa ratione saepe sunt voluptatibus fuga perspiciatis reiciendis qui impedit nam itaque incidunt.</p>
  </section>  
  <section class="bg3">
    <h1>CONTACT</h1>
    <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Laborum perspiciatis, quae tempore voluptas modi dignissimos asperiores quibusdam adipisci eligendi facilis eos eius corrupti, numquam nulla dolorum, impedit rem fugit rerum?</p>
  </section>
</div>

P.S:不要忘记将所需的遗留 -vendor-前缀添加到所需的CSS3属性

答案 1 :(得分:1)

这是一个多步骤的过程:

1 /听取按钮上的点击事件,需要点击切换内容

2 /单击时,您可以使用animate功能将要替换的内容从容器div中滑出。像

这样的东西
$('#id1').animate({'margin-left':'-=500px'},500)

应该有效。第二个“500”是动画的速度。

3 /然后您需要使用相同的功能来滑动您希望显示的内容。

4 /当然你需要正确的CSS风格。类似的东西:

#content{
   width:100px //width of your div
   height : 100px // height of your div
   overflow : hidden;
}

答案 2 :(得分:0)

我会玩一点并查看来源以了解如何手动完成。您可以从检查这个开始:http://css-tricks.com/examples/AnythingSlider/

如果不是,它有完整的下载源和关于如何实现它的文档

答案 3 :(得分:0)

更改div内容的最佳方法是在其中提供sub-div。

最初制作一个display:none;并根据某些条件将其设为display:block;

它适用于Chrome,FF和IE。