通过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 相关文章推荐
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
Aug 30 Javascript
jQuery中prependTo()方法用法实例
Jan 08 Javascript
JS动态修改图片的URL(src)的方法
Apr 01 Javascript
JavaScript动态添加事件之事件委托
Jul 12 Javascript
JS框架之vue.js(深入三:组件1)
Sep 29 Javascript
JS动态计算移动端rem的解决方案
Oct 14 Javascript
详解tween.js的使用教程
Sep 14 Javascript
JavaScript生成指定范围随机数和随机序列的方法
May 05 Javascript
vue 对象添加或删除成员时无法实时更新的解决方法
May 01 Javascript
Vue路由 重定向和别名的区别说明
Sep 09 Javascript
vue-quill-editor插入图片路径太长问题解决方法
Jan 08 Vue.js
开发一个封装iframe的vue组件
Mar 29 Vue.js
浅析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下操作Linux消息队列完成进程间通信的方法
2010/07/24 PHP
php中使用接口实现工厂设计模式的代码
2012/06/17 PHP
php生成QRcode实例
2014/09/22 PHP
PHP产生不重复随机数的5个方法总结
2014/11/12 PHP
使用PHP+MySql实现微信投票功能实例代码
2017/09/29 PHP
PHP生成二维码与识别二维码的方法详解【附源码下载】
2019/03/07 PHP
jquery 使用简明教程
2014/03/05 Javascript
Jquery全选与反选点击执行一次的解决方案
2015/08/14 Javascript
js实现点击文本框显示日期选择器特效代码分享
2020/05/21 Javascript
JavaScript SHA-256加密算法详细代码
2016/10/06 Javascript
浅谈Angular路由守卫
2017/08/26 Javascript
实例分析js事件循环机制
2017/12/13 Javascript
angular动态表单制作
2018/02/23 Javascript
Node.js利用console输出日志文件的方法示例
2018/04/27 Javascript
JavaScript中发出HTTP请求最常用的方法
2018/07/12 Javascript
vue利用v-for嵌套输出多层对象,分别输出到个表的方法
2018/09/07 Javascript
Pycharm技巧之代码跳转该如何回退
2017/07/16 Python
Python中的并发处理之asyncio包使用的详解
2018/04/03 Python
pandas 取出表中一列数据所有的值并转换为array类型的方法
2018/04/11 Python
Django实现auth模块下的登录注册与注销功能
2019/10/10 Python
Python实现播放和录制声音的功能
2020/08/12 Python
国外平面设计素材网站:The Hungry JPEG
2017/03/28 全球购物
欧尚俄罗斯网上超市:Auchan俄罗斯
2018/05/03 全球购物
eharmony澳大利亚:网上约会服务
2020/02/29 全球购物
英国豪华家具和经典家居饰品购物网站:OKA
2020/06/05 全球购物
简述DNS进行域名解析的过程
2013/12/02 面试题
中科软笔试题和面试题
2014/10/07 面试题
自荐书范文
2013/12/08 职场文书
网上卖盒饭创业计划书范文
2014/02/07 职场文书
大学生职业规划书的范本
2014/02/18 职场文书
高中生学期学习自我评价
2014/02/24 职场文书
学雷锋树新风演讲稿
2014/05/10 职场文书
企业文化理念标语
2014/06/10 职场文书
通用员工手册范本
2015/05/14 职场文书
入党介绍人意见范文
2015/06/01 职场文书
Vue2项目中对百度地图的封装使用详解
2022/06/16 Vue.js