我有一个名为“背景”的div,其中有4个图像(400x300px),每x秒连续淡入淡出。此代码显示浏览器左上角的图像。我想要的是将它移到容器内的其他地方,但我不能。我尝试通过将位置更改为“相对”并使用“边距”,div“背景移动到我设置的任何位置,但淡入淡出图像仍保留在左上角。 您可以在下面看到代码。有什么想法吗?
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Image Change</title>
<style type="text/css">
div.background {
position:relative;
width:500px;
height:500px;
margin-left:50px;
margin-top:50px;
background:red;
z-index:-1;}
div.background img {
position:fixed;
list-style: none;
left:0px;
top:0px;}
div.background ul li.show {
z-index:500}
div.background { position:absolute; left:0px; top:0px; z-index:-1;}div.background img { position:fixed; list-style: none; left:0px; top:0px;}div.background ul li.show { z-index:500}
</style>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
<script type="text/javascript">
function thebackground() {
$('div.background img').css({opacity: 0.0});
$('div.background img:first').css({opacity: 1.0});
setInterval('change()',4000);
}
function change() {
var current = ($('div.background img.show')? $('div.background img.show') : $('div.background img:first'));
if ( current.length == 0 ) current = $('div.background img:first');
var next = ((current.next().length) ? ((current.next().hasClass('show')) ? $('div.background img:first') :current.next()) : $('div.background img:first'));
next.css({opacity: 0.0})
.addClass('show')
.animate({opacity: 1.0}, 1000);
current.animate({opacity: 0.0}, 1000)
.removeClass('show');
};
$(document).ready(function() {
thebackground();
$('div.background').fadeIn(1000); // works for all the browsers other than IE
$('div.background img').fadeIn(1000); // IE tweak
});
</script>
</head>
<body>
<div class="background">
<img src="images/image1.jpg" />
<img src="images/image2.jpg" />
<img src="images/image3.jpg" />
<img src="images/image4.jpg" />
</div>
</body>
</html>
答案 0 :(得分:1)
这是您的预期结果吗?
在这种情况下,请尝试将CSS更改为position: relative
和position: absolute
:
div.background {position:relative; left:0px; top:0px; z-index:-1;}
div.background img {position:absolute; left:0px; top:0px;}
也改变了这一行:
setInterval('change()',4000);
与
setInterval(change(),4000);