单击图像,隐藏其他图像并使用JQUERY对图像滑动进行动画处理
Click image, hide other images and animate image sliding with JQUERY
只是想先说这是我的第一篇文章,但绝对是这些论坛的长期读者,所以要善良。
我正在使用什么:
jQuery 和 Bootstrap 3
我想要完成什么
我有 5 张图像居中。我希望能够单击其中一个图像并发生以下情况:
淡出或隐藏其他 4 张图像,将剩余图像滑动到行的最左侧,然后滑入另一个div 以用作其他内容的容器。(我能够让代码根据图像点击更改内容,只需要动画部分的帮助)。
这是我能够完成的JSFiddle。感谢这个问题以外的任何帮助(代码礼仪等)。现在只做了大约 3 个月左右,但玩得很开心。仍然习惯一些术语,所以像我 5 岁一样解释是可以的。
编辑 1:http://jsfiddle.net/eps7tpyd/这里有一些更接近的东西,但是向右移动的div 的动画似乎只发生在第一个,我怀疑这是因为它的类是唯一改变的。其他div 不需要更改类即可向左移动。因为其他的被隐藏了,所以它们在引导行中一直向左移动。
Edit2:这是我对其他尝试的人的最终解决方案(没有揭示div功能,但不要认为这太难做到。如果我在第二天左右有机会,我会在完成后发布它。http://jsfiddle.net/8g9tL5zw/
简讯
$(document).ready(function () {
$('div.container2').hide();
$('div.roster').click(function () {
if ($(this).hasClass("offset")) {
$(this).toggleClass("col-xs-offset-1");
$('div.roster').not(this).fadeToggle();
$('div.container2').toggle();
} else {
$('div.roster').not(this).fadeToggle();
$('div.container2').toggle();
}
});
});
.HTML
<section class="container">
<article class="row roster">
<div class="col-xs-2 col-xs-offset-1 roster offset">
<img src="http://dummyimage.com/308x560/000/fff" class="img-responsive player" />
</div>
<div class="col-xs-2 roster">
<img src="http://dummyimage.com/308x560/0000ff/000" class="img-responsive player" />
</div>
<div class="col-xs-2 roster">
<img src="http://dummyimage.com/308x560/800080/000" class="img-responsive player" />
</div>
<div class="col-xs-2 roster">
<img src="http://dummyimage.com/308x560/008000/000" class="img-responsive player" />
</div>
<div class="col-xs-2 roster">
<img src="http://dummyimage.com/308x560/ffff00/000" class="img-responsive player" />
</div>
<div class="container2">TEST</div>
</article>
</section>
.CSS
.container {
width: 95%;
margin-top: 15px;
}
article .roster {
overflow: hidden;
-webkit-transition: width 0.1s ease, margin 0.1s ease;
-moz-transition: width 0.1s ease, margin 0.1s ease;
-o-transition: width 0.1s ease, margin 0.1s ease;
transition: width 0.1s ease, margin 0.1s ease;
}
.player-info {
display: inline-block;
color: blue;
width: 80%;
height: 400px;
position: relative;
z-index: -1;
background-color: red;
}
我已经准备了 jsfiddle 来扩展您的解决方案,并希望这就是您想要的
我的解决方案 一步一步:
.HTML:
我在最后一个播放器之后添加了.content
容器(.clearfix
将其保留在所有容器下,并使用一些引导网格类)
<br class="clearfix" />
<div class="col-xs-8 col-xs-offset-3 content"></div>
此外,在每个播放器之后,我都为该播放器添加了内容(简单的文本和图像)
<div id="content3">
This is the content for player 3<br/>
<img src="http://lorempixel.com/400/200/" alt=""/>
</div>
.CSS:
使用CSS,我把:
.content {
background: #dadada;
height: 286px;
position: absolute; // to keep it over players from 2 to 5
top: 0;
display: none; // hide for start
}
我已经更新了您的两个 CSS 片段,如下所示(只需添加 .content 类):
#player2-col, #player3-col, #player4-col, #player5-col, .content {
transition: transform .5s linear;
-webkit-transition: transform .5s ease;
}
#player1, #player2, #player3, #player4, #player5, .content {
transition: transform .7s ease;
}
当然,在开始时隐藏玩家的内容:
[id^="content"] {
display: none;
}
.JS:在JavaScript中,我添加了一个局部变量($parentDiv
)只是为了优化,以及两行代码:
// toggle element after each player click
$('.content').toggle("drop");
// update main content container with content for specific player
$('.content').html($parentDiv.find('[id^="content"]').html());
就这样。希望对:)有所帮助
这是我使用引导程序作为框架并使用jquery进行动画所能完成的(稍后我将考虑添加显示另一个容器,因为我很好地掌握了它是如何工作的)我感谢所有的评论并尝试提供帮助!这是我的最终结果 http://jsfiddle.net/8g9tL5zw/
$('.portrait').on('click' , function(){
$('.portrait').not(this).toggle("drop");
if($(this).parent('div').is('#player2-col')){
$(this).parent('div').toggleClass("move-player2");
}
else if ($(this).parent('div').is('#player3-col')){
$(this).parent('div').toggleClass("move-player3");
}
else if ($(this).parent('div').is('#player4-col')){
$(this).parent('div').toggleClass("move-player4");
}
else if ($(this).parent('div').is('#player5-col')){
$(this).parent('div').toggleClass("move-player5");
}
});
尝试使用 Web 动画 API
最简单的参考:http://updates.html5rocks.com/2014/05/Web-Animations---element-animate-is-now-in-Chrome-36
从您的示例中听起来您想通过过滤器选项隐藏和显示项目元素。隐藏与所选项目不匹配的项目时将被隐藏。同位素将是 http://isotope.metafizzy.co/filtering.html 的最佳解决方案。我会选择fitRows选项,因为它非常适合具有相同高度的物品。这个新功能的最大优点是消除了许多尴尬的箍和测试,我们必须经历才能达到预期的结果。同位素提供丝般流畅的动画。
有关安装的最佳分步帮助,请查看 http://bootstrapwp.com/?ref=14
- 使用javascript制作图像动画
- 图像动画不平滑
- 循环图像动画
- Javascript图像动画闪烁图像错误
- Javascript图像动画在Firefox或Internet Explorer中不起作用
- 具有速度控制的图像动画
- 我正在尝试使用JQuery使点击的图像动画化到它们的位置
- 没有水平滚动条的 Jquery 图像动画
- JavaScript动画,图像动画只动画一次
- 为什么在Android上快速更改背景图像(动画)如此缓慢
- 设置图像动画'使用jQuery的透视图
- KineticJS如何设置图像动画
- 使用jquery动画效果制作图像动画
- HTML5画布缩放图像动画
- 如何向左或向右创建运动图像动画
- 如何改进RaphaëlJS图像动画
- HTML5画布线性图像动画
- 单击按钮时出现图像动画问题
- Nedd可以通过点击HTML5模板中的一个按钮来播放音频片段和图像动画
- 画布图像动画(交叉渐变)