我有一个CSS + Javascripts幻灯片,取自W3Schools website example。
这是代码,适应我的网页应用程序(几乎相同):
$(document).ready(function() {
var slideIndex = 1;
function showSlides(n) {
var slides = $(".mySlides");
var i;
if (n > slides.length) {
slideIndex = 1;
}
if (n < 1) {
slideIndex = slides.length;
}
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
slides[slideIndex - 1].style.display = "block";
}
function plusSlides(n) {
showSlides(slideIndex += n);
}
showSlides(slideIndex);
$(".prev").click(function() {
plusSlides(-1);
});
$(".next").click(function() {
plusSlides(1);
});
});
@-webkit-keyframes fade {
from {
opacity: .4
}
to {
opacity: 1
}
}
@keyframes fade {
from {
opacity: .4
}
to {
opacity: 1
}
}
.slideshow-container {
position: relative;
margin: auto;
}
.prev,
.next {
cursor: pointer;
position: absolute;
top: 0;
top: 50%;
width: auto;
margin-top: -22px;
padding: 16px;
color: white;
font-weight: bold;
font-size: 18px;
transition: 1.6s ease;
border-radius: 0 3px 3px 0;
}
.next {
right: 0;
border-radius: 3px 0 0 3px;
}
.prev:hover,
.next:hover {
background-color: rgba(0, 0, 0, 0.8);
}
.text {
color: #f2f2f2;
font-size: 15px;
padding: 8px 12px;
position: absolute;
bottom: 8px;
width: 100%;
text-align: center;
}
.numbertext {
color: #f2f2f2;
font-size: 12px;
padding: 8px 12px;
position: absolute;
top: 0;
}
.fade {
-webkit-animation-name: fade;
-webkit-animation-duration: 1.5s;
animation-name: fade;
animation-duration: 1.5s;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="slideshow-container">
<div class="mySlides fade">
<div class="numbertext">1 / 3</div>
<img class="img-responsive" src="pic1.jpg" alt='Entrada'>
<div class="text">1</div>
</div>
<div class="mySlides fade">
<div class="numbertext">2 / 3</div>
<img class="img-responsive" src="pic2.jpg">
<div class="text">2</div>
</div>
<div class="mySlides fade">
<div class="numbertext">3 / 3</div>
<img class="img-responsive" src="pic3.jpg">
<div class="text">3</div>
</div>
<a class="prev">❮</a>
<a class="next">❯</a>
</div>
页面正确加载,但图片在一秒左右后消失。
我该如何解决?
答案 0 :(得分:1)
我有一段时间没有同样的问题。我已经通过添加animation-fill-mode: forwards;
解决了这个问题。
通常,动画会运行并停止,然后返回原始样式。
使用animation-fill-mode
,您可以更改该行为。 forwards
将在动画结束后保持动画的结果。
请参阅CSS代码段的底部以了解实现。
$(document).ready(function() {
var slideIndex = 1;
function showSlides(n) {
var slides = $(".mySlides");
var i;
if (n > slides.length) {
slideIndex = 1;
}
if (n < 1) {
slideIndex = slides.length;
}
for (i = 0; i < slides.length; i++) {
slides[i].style.display = "none";
}
slides[slideIndex - 1].style.display = "block";
}
function plusSlides(n) {
showSlides(slideIndex += n);
}
showSlides(slideIndex);
$(".prev").click(function() {
plusSlides(-1);
});
$(".next").click(function() {
plusSlides(1);
});
});
@-webkit-keyframes fade {
from {
opacity: .4
}
to {
opacity: 1
}
}
@keyframes fade {
from {
opacity: .4
}
to {
opacity: 1
}
}
.slideshow-container {
position: relative;
margin: auto;
}
.prev,
.next {
cursor: pointer;
position: absolute;
top: 0;
top: 50%;
width: auto;
margin-top: -22px;
padding: 16px;
color: white;
font-weight: bold;
font-size: 18px;
transition: 1.6s ease;
border-radius: 0 3px 3px 0;
}
.next {
right: 0;
border-radius: 3px 0 0 3px;
}
.prev:hover,
.next:hover {
background-color: rgba(0, 0, 0, 0.8);
}
.text {
color: #f2f2f2;
font-size: 15px;
padding: 8px 12px;
position: absolute;
bottom: 8px;
width: 100%;
text-align: center;
}
.numbertext {
color: #f2f2f2;
font-size: 12px;
padding: 8px 12px;
position: absolute;
top: 0;
}
.fade {
-webkit-animation-name: fade;
-webkit-animation-duration: 1.5s;
-webkit-animation-fill-mode: forwards;
animation-name: fade;
animation-duration: 1.5s;
animation-fill-mode: forwards;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="slideshow-container">
<div class="mySlides fade">
<div class="numbertext">1 / 3</div>
<img class="img-responsive" src="http://placehold.it/350x150" alt='Entrada'>
<div class="text">1</div>
</div>
<div class="mySlides fade">
<div class="numbertext">2 / 3</div>
<img class="img-responsive" src="http://placehold.it/350x150">
<div class="text">2</div>
</div>
<div class="mySlides fade">
<div class="numbertext">3 / 3</div>
<img class="img-responsive" src="http://placehold.it/350x150">
<div class="text">3</div>
</div>
<a class="prev">❮</a>
<a class="next">❯</a>
</div>