通过JQuery实现win8一样酷炫的动态磁贴效果(示例代码)


Posted in Javascript onJuly 13, 2013

我个人表示非常喜欢微软新一代的产品,先不管它产品的成熟与否,但是它带来的是全新的产品。所谓全新,是指在用户体验上,苹果这些年的成功使得所有产品都在模仿它的界面,包括安卓在内,不知道大家的感觉如何,反正我是对这些圆角矩形产生了审美疲劳(苹果以及安卓的粉丝勿喷,这里仅仅是从界面上评价,事实上从整体上来说,微软还是有差距的),当年wp的推出让我眼前一亮,马上喜欢上了Metro风格的产品,直至今天wp8以及win8开始越来越成熟。

写的不好,欢迎各位看官指正批评,不欢迎无故猛喷。大神请绕道。

废话少说,进入正题。基本思想是:定义一个外层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://xxxxxxxxx图片地址" />
        <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函数。
源码基本都贴出来了,有需要源文件的童鞋可以猛击这里下载
Javascript 相关文章推荐
获取Javscript执行函数名称的方法
Dec 22 Javascript
jQuery页面滚动浮动层智能定位实例代码
Aug 23 Javascript
利用javascript解决图片缩放及其优化的代码
May 23 Javascript
有关于JS辅助函数inherit()的问题
Apr 07 Javascript
JavaScript中“过于”犀利地for/in循环使用示例
Oct 22 Javascript
jquery中的过滤操作详细解析
Dec 02 Javascript
Jquery使用val方法读写value值
May 18 Javascript
bootstrap table表格插件使用详解
May 08 Javascript
jQuery+Ajax实现用户名重名实时检测
Jun 01 jQuery
JavaScript实现旋转轮播图
Aug 18 Javascript
解决Mac node版本升级失败的问题
May 16 Javascript
微信小程序入口场景的问题集合与相关解决方法
Jun 26 Javascript
浅析ajax请求json数据并用js解析(示例分析)
Jul 13 #Javascript
网页前端优化之滚动延时加载图片示例
Jul 13 #Javascript
JavaScript获取FCK编辑器信息的具体方法
Jul 12 #Javascript
javascript 实现 秒杀,团购 倒计时展示的记录 分享
Jul 12 #Javascript
jquery实现微博文字输入框 输入时显示输入字数 效果实现
Jul 12 #Javascript
jquery 滚动条事件简单实例
Jul 12 #Javascript
简约JS日历控件 实例代码
Jul 12 #Javascript
You might like
smarty获得当前url的方法分享
2014/02/14 PHP
PHP实现将浏览历史页面网址保存到cookie的方法
2015/01/26 PHP
JavaScript实现删除电脑的关机键
2016/07/26 PHP
tp5实现微信小程序多图片上传到服务器功能
2018/07/16 PHP
零基础php编程好学吗
2019/10/11 PHP
js 巧妙去除数组中的重复项
2010/01/25 Javascript
JavaScript中的16进制字符(改进)
2011/11/21 Javascript
JavaScript实现数字数组正序排列的方法
2015/04/06 Javascript
js实现浮动在网页右侧的简洁QQ在线客服代码
2015/09/04 Javascript
JS+CSS实现类似QQ好友及黑名单效果的树型菜单
2015/09/22 Javascript
使用jQuery操作DOM的方法小结
2017/02/27 Javascript
JavaScript实现前端分页控件
2017/04/19 Javascript
20行JS代码实现网页刮刮乐效果
2017/06/23 Javascript
vuejs使用FormData实现ajax上传图片文件
2017/08/08 Javascript
Vue中的methods、watch、computed的区别
2018/11/26 Javascript
nodejs的安装使用与npm的介绍
2019/09/11 NodeJs
layer弹出框确定前验证:弹出消息框的方法(弹出两个layer)
2019/09/21 Javascript
vue 导航内容设置选中状态样式的例子
2019/11/01 Javascript
d3.js实现图形缩放平移
2019/12/19 Javascript
用Python编写web API的教程
2015/04/30 Python
使用python实现rsa算法代码
2016/02/17 Python
在Linux命令行终端中使用python的简单方法(推荐)
2017/01/23 Python
python实现k-means聚类算法
2018/02/23 Python
python pandas修改列属性的方法详解
2018/06/09 Python
解决python 未发现数据源名称并且未指定默认驱动程序的问题
2018/12/07 Python
python 产生token及token验证的方法
2018/12/26 Python
pycharm部署、配置anaconda环境的教程
2020/03/24 Python
python对指定字符串逆序的6种方法(小结)
2020/04/02 Python
司机岗位职责
2013/11/15 职场文书
《青山处处埋忠骨》教学反思
2014/04/22 职场文书
工会主席事迹材料
2014/06/03 职场文书
公安学专业求职信
2014/07/27 职场文书
国王的演讲观后感
2015/06/03 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers
Java基础之this关键字的使用
2021/06/30 Java/Android
MySQL数据库完全卸载的方法
2022/03/03 MySQL