WEB开发网
开发学院网页设计JavaScript 用JQuery实现win8一样酷炫的动态磁贴效果 阅读

用JQuery实现win8一样酷炫的动态磁贴效果

 2013-05-12 14:02:44 来源:开发学院   
核心提示:定义一个外层div,固定高度(例如本例中的180px)并设置属性overflow:hidden(隐藏超出边框的部分),用JQuery实现win8一样酷炫的动态磁贴效果,然后在这个div里面定义一个内层div,并设置属性position:relative(采用相对布局),然后我们在页面加载完成的时候设置一个定时器,来执行

定义一个外层div,固定高度(例如本例中的180px)并设置属性overflow:hidden(隐藏超出边框的部分),然后在这个div里面定义一个内层div,并设置属性position:relative(采用相对布局)。在这个内层div里面,我们定义一张图片,注意要设置它的高度跟外层div高度一样(如本例中的180px),再定义一个div放文字,该div的高度也和外层div高度一样(如本例中的180px,如果你给了一个padding,则高度相应减小,以达到整个div是180px的高度)。布局代码如下所示

html:


<div id="outside">
<div id="inside">
<img width="180px" height="180px" src="http://pic.cnitblog.com/avatar/505350/20130316011725.png" />
<div id="text">
<span>通过JQuery实现win8一样酷炫的动态磁贴效果</span>
<p>林宇</p>
<p>我个人表示非常喜欢微软新一代的产品……</p>
</div>
</div>
</div>

css:


#outside
{
height:180px;
overflow:hidden;
}
#inside
{
position:relative;
}
#text
{
width:160px;
height:160px;
background:#0000ff;
padding:10px;
color:#fff;
}

剩下来的就是JQuery的事情了。首先先理解一下这个“动态磁贴”的动作:一开始显示一张图片,然后向上滑动显示文字,停留一会,再向下滑动显示图片,如此循环。我们先定义一个函数:


function go(id, d1, px1, val1, d2, px2, val2) {
$(id).delay(d1);
$(id).animate({ bottom: px1 }, val1, function () {
$(id).delay(d2);
$(id).animate({ bottom: px2 }, val2);
});
}

这里有7个参数,id是内层div也就是要滑动的div的id,d1是内层div滑上去以后停留的时间,px1是内层div要向上滑动的相对位置,默认当前位置为0px,val1是内层div的完成向上滑动动作所需要的时间,d2是向下滑动div后停留的时间,px2是向下滑动的相对位置,这里依然是以原来的位置为0px,val2是完成向下滑动所需的时间。

然后我们在页面加载完成的时候设置一个定时器,来执行我们定义的go函数:

$(function () {
timer1 = setInterval(function () {
go("#inside", 1500, "180px", 1200, 1000, "0px", 2000);
}, 3000);
});
这里的参数可以根据需要进行修改,这里我们让定时器每3秒执行一次go函数。 

Tags:JQuery 实现 win

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接