[英]Hide/Show image after 2 seconds
所以我需要有一个图像交替出现并且每2秒消失一次,我一直在尝试使用javascript而且我已经卡住了,我觉得它很简单,但我无法解决,任何帮助都表示赞赏。
HTML
<body onload="Show()">
<div align="center">
<img id="image" src="image1.png" height="200" width="200">
JAVASCRIPT
var Cntr=1
function Hide()
{
Cntr++;
document.getElementById("image").style.visibility="hidden";
if (Cntr==2){
setTimeout("Hide", 2000);
}
}
function Show()
{
Cntr--;
document.getElementbyId("image").style.visibility="visible";
if (Cntr==1) {
setTimeout("Show", 2000);
}
}
您的代码存在很多问题。
正如Juhana所提到的,你正在使用setTimeout
错误。
Hide()
不会在任何地方被调用。
这是你可以做的:
// Store the status of the image. Initially it is 'visible'.
var isVisible = "visible";
function blink() {
// Toggle the position.
if(isVisible == "visible") isVisible = "hidden";
else isVisible = "visible";
// Update it.
document.getElementById("image").style.visibility = isVisible;
// Repeat the process every 2 seconds.
setTimeout(blink, 2000);
}
<body onload="blink()">...</body>
工作实例 。
我把你的javscript更改为:
var hidden = false;
setInterval(function(){
document.getElementById("image").style.visibility= hidden ? "visible" : "hidden";
hidden = !hidden;
},2000);
并从<body>
标签中删除了onload
函数。
这里也是一个JSFIDDLE 。
在你setTimeout()的交换显示和隐藏。 另外,删除var Cntr。 不需要它
function Hide()
{
document.getElementById("image").style.visibility="hidden";
setTimeout("Show()", 2000);
}
function Show()
{
document.getElementbyId("image").style.visibility="visible";
setTimeout("Hide()", 2000);
}
尝试这个 -
$(function($) { setInterval(function() { if($('#image').is(':visible')) $('#image').hide(); else $('#image').show(); }, 2000); });
使用jQuery代替原始JS,它更干净简单。 使用Delay和FadeTo函数进行递归,您可以使用一个简单的函数。 在页面加载时调用此方法。
function Flicker(){
$("#MyImage").delay(1500).fadeTo(300,0).delay(1500).fadeTo(300,1, Flicker);
}
其中:#MyImage是图像的ID。
你可以看到这个工作@ http://jsfiddle.net/BM3qK/1/
希望这可以帮助。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.