- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到一个问题,每秒出现一个新图像时,我需要在页面上淡入和淡出 6 个随机图像。我已经尝试过在网上找到的代码,但它只在随机位置的一张图像中淡入淡出,而不会淡入/淡出其他图像。如果您能帮助我,我将非常感激。
代码:
$(document).ready(showLetter);
var imgsArray = ["backgroundI1", "backgroundI2", "backgroundI3", "backgroundI4", "backgroundI5", "backgroundI6"];
function generateRandomForArray() {
var num = Math.floor(Math.random() * 8);
return num;
}
function generateRandom() {
var num = Math.floor(Math.random() * 400);
return num;
}
function showLetter() {
var name = imgsArray[generateRandomForArray()];
$(".heroBackground").append("<img src='media/backgroundImages/" + name + ".png'>");
var left = generateRandom();
var top = generateRandom();
$(".heroBackground").last().css({ "position": "absolute", "top": top + "px", "left": left + "px" });
}
再次感谢您!
最佳答案
替代解决方案,使用 css 进行动画,并使用一个小的 javascript 片段来重置动画,因为 css 中存在令人讨厌的限制,您不能在动画重复中出现延迟。
通过这种方式,如果您正在运行大量长循环的其他 JavaScript,并且只有在其他事情完成时才会重新启动,那么您可能会面临间隔时间有时与图像 slider 异步运行的风险(有点晚)。
但另一方面,您可以使用精美的 css3 转换,并且不需要在 javascript 中管理时间。
/**
* replace with your own function that supplies array of random images.
*/
function getRandomImages() {
var random = ['https://i.imgur.com/Y7icJAN.jpg','https://i.imgur.com/IX9YUcq.jpg','https://i.imgur.com/8p6P3gN.jpg','https://i.imgur.com/bAglKHW.jpg','https://i.imgur.com/VG0nBdD.jpg','https://i.imgur.com/vkUNuCx.jpg'];
return random;
}
/** apply random images **/
var images = getRandomImages();
$('.hero .background').each(function(index, elem) {
$(this).css({'background-image':"url('" + images[index] + "')"});
});
resetAnimationOnHeroes();
function resetAnimationOnHeroes() {
var heroes = $('.hero .background');
heroes.css({'animation':'none'});
/** need timeout here so browser will not see all javascript changes as one instruction and only apply the last one **/
window.setTimeout(function() {
heroes.css({'animation':''});
},10);
}
window.setInterval(resetAnimationOnHeroes, (15 * 1000) + 250);
.hero {
width: 100%;
height:200px;
position:relative;
}
.hero .background {
background-size:cover;
background-position: center;
background-color:black;
width:100%;
opacity: 0;
height: 200px;
animation: fadeHero 3s linear;
position:absolute;
top:0px;
left:0px;
}
.hero .background:nth-child(1) {
animation-delay: 0s;
}
.hero .background:nth-child(2) {
animation-delay: 2.5s;
}
.hero .background:nth-child(3) {
animation-delay: 5s;
}
.hero .background:nth-child(4) {
animation-delay: 7.5s;
}
.hero .background:nth-child(5) {
animation-delay: 10s;
}
.hero .background:nth-child(6) {
animation-delay: 12.5s;
}
@keyframes fadeHero {
0% {
opacity:0;
}
25% {
opacity: 1;
}
75% {
opacity:1;
}
100% {
opacity: 0;
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="hero">
<div class="background"></div>
<div class="background"></div>
<div class="background"></div>
<div class="background"></div>
<div class="background"></div>
<div class="background"></div>
</div>
关于javascript - 在页面中随机淡入和淡出图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48056769/
我似乎对 git 存储库有权限问题。 当我 pull 入一个不是我的 Linux 用户创建的目录时,我出现了这个错误。 fatal: Unable to create '/home/---/.git/
在 Git 中,您可以将给定目录克隆到给定目录: git clone ssh://gitolite@dev.bipper.com:3687/com/bipper/kids/portal 当我运行我们
目前,如果您在分支 V2 中并执行“git pull origin V3”,它会将 V3 merge 到 V2,甚至不会发出警告或提示。这个选项可以以某种方式被阻止吗?我在这里阅读了所有类似的问题,人
我刚开始使用 Oracle 的 Coherence 缓存,我注意到这一点:如果我在缓存中放入一个 ConcurrentHashMap 对象,当我检索它时,我可以看到它被转换为一个普通的 HashMap
看起来我缺少对 git pull 和 git commit 的基本理解,假设我在分支上工作,而它在我更新时被其他开发人员更新了在本地做我的工作。我应该在发出 git pull 之前提交更改,还是应该执
好的。所以我以为我已经舔过了……但现在…… 我有一个项目,其中包含一个来自 GitHub 的小型库作为子模块。在该 super 项目的原始版本中,子模块按预期工作。 但是,我只是克隆了 super 项
使用 Visual Studio Code 中的内置 Git,我看不到将指定的远程分支 pull 入当前分支的方法。我可以这样做吗? 示例:我正在分支 myBranch 上工作,更改已 merge 到
当我尝试提交或 pull 此错误时 Bus error (core dumped) 发生了! 当我用 gdb 调试它时,(gdb git,run commit -a,where) 结果是: mucul
我对默认 Rails Rake 任务的预期用途有点困惑,想咨询一下我是否应该使用 db:reset或编写自定义 Rake 任务。没什么聪明的,只是日常管理,而且我很可能会错过一个明显的文档,因为我是
所以我做了: git reset --hard #commithash # make a bunch of changes, fixes and so on. git add -A git commi
我已使用以下命令成功部署到 firebase 托管应用: firebase init firebase deploy 在这个阶段,我正在执行 git pull 以将 repo 下 pull 到暂存服务
当尝试在 Eclipse 的 git 存储库中 pull (团队|从上下文菜单中 pull )时,出现 Could not get advertised Ref for branch refs/hea
我是一名优秀的程序员,十分优秀!