更新:效果正常。 剩下的最后一件事就是试图通过我似乎无法figure out的div来滑动。
更新:我已成功使用transitions plugin。还有一个问题是:当文本在框中滑动时,我可以看到它是如何从外部进入盒子的。 Click here看看我的意思。
我想使用jQuery(top - > flash,bottom - > jquery)来实现this flash effect,以便在iphone和智能手机上查看。
此刻,我无法让文字从这些框下方滑入。
HTML code:
<div id="banner">
<div>
<img src="img/banner-1.jpg" class="banner-bg" />
<div class="left"></div>
<div class="left-text"><span>POLISHED FLOORS1</span></div>
<div class="right"></div>
<div class="right-text"><span>Custom-made, elegant and long lasting.</span></div>
</div>
<div>
<img src="img/banner-2.jpg" class="banner-bg" />
<div class="left"></div>
<div class="left-text"><span>POLISHED FLOORS2</span></div>
<div class="right"></div>
<div class="right-text"><span>Custom-made, elegant and long lasting.</span></div>
</div>
<div>
<img src="img/banner-3.jpg" class="banner-bg" />
<div class="left"></div>
<div class="left-text"><span>POLISHED FLOORS3</span></div>
<div class="right"></div>
<div class="right-text"><span>Custom-made, elegant and long lasting.</span></div>
</div>
</div>
jQuery代码:
$(document).ready(function(){
//$("#banner .left").transition({opacity: "1", width: "238px"}, 1200);
//$("#banner .right").transition({opacity: "0.7", width: "662px"}, 1200);
//$("#banner .left-text").delay(1200).transition({ opacity: '1', x: '-220px' });
//$("#banner .right-text").delay(1200).transition({ opacity: '1', x: '+642px' });
$(function(){
$ds = $('#banner div .banner-bg');
$ds.hide().eq(0).show();
setInterval(function(){
$ds.filter(':visible').fadeOut(function(){
var $banner_bg = $(this).next('div .banner-bg');
var $left = $(this).next('div .left');
var $right = $(this).next('div .right');
var $left_text = $(this).next('div .left-text');
var $right_text = $(this).next('div .right-text');
if ( $banner_bg.length == 0 ) {
$ds.eq(0).fadeIn();
} else {
$left.transition({opacity: "1", width: "238px"}, 1200);
$right.transition({opacity: "0.7", width: "662px"}, 1200);
$left_text.delay(1200).transition({ opacity: '1', x: '-220px' });
$right_text.delay(1200).transition({ opacity: '1', x: '+642px' });
$banner_bg.fadeIn();
}
});
}, 5000);
});
});
CSS代码:
#banner {
height:299px;
width:900px;
position:relative;
overflow:hidden;
}
#banner .banner-bg {
z-index:0;
position:absolute;
top:0;
left:0;
}
#banner .left {
float:left;
width:0px;
height:100px;
background:url(img/banner-left-bg.png);
opacity:0.3;
position:relative;
z-index:7;
}
#banner .right {
float:right;
width:0px;
height:100px;
background-color:#34515c;
opacity:0.3;
position:relative;
z-index:5;
}
#banner .left-text, #banner .right-text {
font-family:Verdana, Arial;
font-size:22px;
font-style:normal;
color:#fff;
top:35px;
}
#banner .left-text {
position:absolute;
left:233px;
opacity:0;
z-index:8;
}
#banner .right-text {
position:absolute;
right:662px;
width:630px;;
font-size:24px;
opacity:0;
z-index:6;
}
有什么建议吗?
答案 0 :(得分:7)
我创建了jsFiddle在线标记。
解决方案是为左侧文本块设置z-index
值,即.left
和.left-text
,以便它涵盖传入的动画。
编辑:对于您的问题中列出的第二个更新,我看到您的在线HTML和在线jQuery是一种完全不同于此处列出的方法。我看到你的目标在哪里,但你的标记中到处都有很多缺失,但是你走的是正确的道路。
我建议使用许多免费幻灯片插件中的一个,它可以与具有动画的独特横幅文本结合使用。在这里查看s3Slider DEMO。这些横幅文本框可以替换为您自己的光滑版本。 s3Slider 主页为HERE。
状态:最后,一个jsFiddle使用经过大量修改的s3Slider jQuery插件重新创建Flash效果,该插件也使用jsLint进行验证。我在那个演示中有很多评论。
LINK: jsFiddle DEMO(2012年12月26日更新)
对于 灵感 ,以下是CSS3广告与Flash广告的一些webkit examples看起来相同。猜猜哪个!
答案 1 :(得分:3)
听起来像#banner
需要overflow: hidden;
。