通过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 相关文章推荐
javascript读取xml
Nov 04 Javascript
通过javascript设置css属性的代码
Dec 28 Javascript
从零开始学习jQuery (八) 插播:jQuery实施方案
Feb 23 Javascript
jsPDF生成pdf后在网页展示实例
Jan 16 Javascript
js获取判断上传文件后缀名的示例代码
Feb 19 Javascript
javascript框架设计之浏览器的嗅探和特征侦测
Jun 23 Javascript
模拟javascript中的sort排序(简单实例)
Aug 17 Javascript
JavaScript中浅讲ajax图文详解
Nov 11 Javascript
angular.js + require.js构建模块化单页面应用的方法步骤
Jul 19 Javascript
Vue入门之数据绑定(小结)
Jan 08 Javascript
JS创建自定义对象的六种方法总结
Dec 15 Javascript
原生js实现九宫格拖拽换位
Jan 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
一些常用的php函数
2006/12/06 PHP
防止MySQL注入或HTML表单滥用的PHP程序
2009/01/21 PHP
PHP 类商品秒杀计时实现代码
2010/05/05 PHP
JavaScript实现班级随机点名小应用需求的具体分析
2014/05/12 Javascript
js实现网页标题栏闪烁提示效果实例分析
2014/11/20 Javascript
node.js中的fs.exists方法使用说明
2014/12/17 Javascript
javascript实现图片自动和可控的轮播切换特效
2015/04/13 Javascript
js生成验证码并直接在前端判断
2015/05/15 Javascript
js计算系统当前日期是星期几的方法
2016/07/14 Javascript
jquery easyui validatebox remote的使用详解
2016/11/09 Javascript
详解React 服务端渲染方案完美的解决方案
2018/12/14 Javascript
详解项目升级到vue-cli3的正确姿势
2019/01/28 Javascript
vuejs移动端实现div拖拽移动
2019/07/25 Javascript
Python进行数据科学工作的简单入门教程
2015/04/01 Python
在Django中创建动态视图的教程
2015/07/15 Python
Django 前后台的数据传递的方法
2017/08/08 Python
Python3.x对JSON的一些操作示例
2017/09/01 Python
python 删除列表里所有空格项的方法总结
2018/04/18 Python
pandas读取csv文件,分隔符参数sep的实例
2018/12/12 Python
Python生成一个迭代器的实操方法
2019/06/18 Python
pyqt实现.ui文件批量转换为对应.py文件脚本
2019/06/19 Python
python打开windows应用程序的实例
2019/06/28 Python
Django的性能优化实现解析
2019/07/30 Python
VSCode中自动为Python文件添加头部注释
2019/11/14 Python
tensorflow 实现自定义layer并添加到计算图中
2020/02/04 Python
基于Python把网站域名解析成ip地址
2020/05/25 Python
Pyinstaller 打包发布经验总结
2020/06/02 Python
css3实现超立体3D图片侧翻倾斜效果
2014/04/16 HTML / CSS
DJI大疆无人机官方商城:全球领先的无人飞行器研发和生产商
2016/12/21 全球购物
英国儿童鞋和靴子:Start-Rite
2019/05/06 全球购物
中职毕业生自我鉴定范文(3篇)
2014/09/28 职场文书
学校教代会开幕词
2016/03/04 职场文书
如何判断微信付款码和支付宝付款码
2021/04/01 PHP
Nginx进程管理和重载原理详解
2021/04/22 Servers
pytorch 中autograd.grad()函数的用法说明
2021/05/12 Python
Java使用httpRequest+Jsoup爬取红蓝球号码
2021/07/02 Java/Android