Twitter Bootstrap Carousel Crossfade
Use the following LESS snippet in your site styles to override the default slide behavior of Bootstrap's carousel to create a crossfade. I've seen other examples on SO for doing this, but all of them had issues either with updated Bootstrap versions or with components like calling .slider(index) to "slide" to a specific item.
.carousel {
.item {
.transition(.7s ease-in-out opacity);
left: 0 !important;
}
.next.left, .prev.right {
opacity: 1;
z-index: 1;
}
.active.left, .active.right {
opacity: 0;
z-index: 2;
}
}
You can see this in action on https://us.pycon.org/2013/ in the sponsor carousel.
Related protips:
Written by Luke Hatcher
Related protips
7 Responses
How does this translate into non .less CSS?
This just worked for me:
carousel .item {
display: none;
position: relative;
-webkit-transition:.7s ease-in-out opacity;
-moz-transition: .7s ease-in-out opacity;
-ms-transition: .7s ease-in-out opacity;
-o-transition: .7s ease-in-out opacity;
transition: .7s ease-in-out opacity;
left: 0 !important;
transition: 0.6s ease-in-out left; */
}
.carousel .next.left,
.carousel .prev.right {
opacity: 1;
z-index: 1;
}
.carousel .active.left {
opacity: 0;
z-index: 2;
}
.carousel .active.right {
opacity: 0;
z-index: 2;
}
you can see the results here:
data:image/s3,"s3://crabby-images/28843/28843df0659ebeb1f2ef6d5cb68b38be7faaf144" alt=""
Thanks to you guys, I now have this (most simply):
.carousel .item {
-webkit-transition: .7s ease-in-out opacity;
-moz-transition: .7s ease-in-out opacity;
-ms-transition: .7s ease-in-out opacity;
-o-transition: .7s ease-in-out opacity;
transition: .7s ease-in-out opacity;
left: 0 !important;
}
.carousel .active.left,
.carousel .active.right {
opacity: 0;
z-index: 2;
}
/--- ...and only if you're using the prev/next buttons ---/
.carousel .next.left,
.carousel .prev.right {
opacity: 1;
z-index: 1;
}
data:image/s3,"s3://crabby-images/d1878/d1878b848462826d257c1a36221be4f9ba91e305" alt=""
I added this to keep the navigation buttons from flashing during the crossfade:
.carousel-control {
z-index:3;
}
data:image/s3,"s3://crabby-images/218ae/218ae2a60da32cacf7594ea78fdaf0f248da4eac" alt=""
Beautiful! Thanks so much. It works great.
data:image/s3,"s3://crabby-images/24366/243662f54fc12f2b4301eceded85643b2be9b587" alt=""
Thanks Luke! Works perfectly in Safari, but not Chrome or FF for me. Is it working for others?
data:image/s3,"s3://crabby-images/6bfa5/6bfa517593f954c28f40e0bcd91a530954c8b7c6" alt=""
estaples, not working in FF or IE, working fine in Chrome