单击图像,隐藏其他图像并使用JQUERY对图像滑动进行动画处理

Click image, hide other images and animate image sliding with JQUERY

本文关键字:图像 动画 处理 隐藏 其他 单击 JQUERY      更新时间:2023-09-26

只是想先说这是我的第一篇文章,但绝对是这些论坛的长期读者,所以要善良。

我正在使用什么:

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