更新:效果很好.剩下的最后一件事就是试图滑过那些我似乎无法弄清楚的div .
更新:我已经成功使用过渡插件.还有一个问题是:当文本在框中滑动时,我可以看到它是如何从外部进入盒子的.点击这里查看我的意思.
我想用jQuery(top - > flash,bottom - > jquery)实现这个flash效果,所以它可以在iphone和智能手机上查看.
目前,我无法从这些框下方滑入文本.
HTML代码:
<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>
Run Code Online (Sandbox Code Playgroud)
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);
});
});
Run Code Online (Sandbox Code Playgroud)
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;
}
Run Code Online (Sandbox Code Playgroud)
有什么建议?
我创建了一个在线标记的jsFiddle.
该解决方案是有一个z-index用于文本的左块的值,即.left与.left-text使得它覆盖传入动画.
编辑:对于您的问题中列出的第二个更新,我看到您的在线HTML和在线jQuery是一种完全不同于您在此处列出的方法.我看到你的目标在哪里,但你的标记中到处都有很多,但是你走的是正确的道路.
我建议使用许多免费幻灯片插件中的一个,它可以与具有动画的独特横幅文本结合使用.在这里看一下s3Slider DEMO.这些横幅文本框可以替换为您自己的光滑版本.该s3Slider主页是这里.
状态:最后,一个jsFiddle使用经过大量修改的s3Slider jQuery插件重新创建Flash效果,该插件也使用jsLint进行验证.我在那个演示中有很多评论.
链接: jsFiddle DEMO(12/26/2012更新)
对于灵感,这里有一些CSS3广告与Flash广告的webkit示例看起来相同.猜猜哪个!