html5中文学习网

您的位置: 首页 > 网站及特效实例 > jquery特效 » 正文

通过JQuery实现win8一样酷炫的动态磁贴效果_编程语言综合

[ ] 已经帮助:人解决问题
相信大家喜欢这个界面无非也是喜欢它的动态磁贴。刚好今天研究了一下如何通过JQuery在网页上模仿这种效果,就贴出来给大家喷一下。虽然是一些很低级的技术,但是也希望有需要的朋友可以参考下
 

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

写的不好,欢迎各位看官指正批评,不欢迎无故猛喷。大神请绕道。iVtHTML5中文学习网 - HTML5先行者学习网

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

复制代码 代码如下:
iVtHTML5中文学习网 - HTML5先行者学习网
<div id="outside">iVtHTML5中文学习网 - HTML5先行者学习网
    <div id="inside">iVtHTML5中文学习网 - HTML5先行者学习网
        <img width="180px" height="180px" src="http://xxxxxxxxx图片地址" />iVtHTML5中文学习网 - HTML5先行者学习网
        <div id="text">iVtHTML5中文学习网 - HTML5先行者学习网
            <span>通过JQuery实现win8一样酷炫的动态磁贴效果</span>iVtHTML5中文学习网 - HTML5先行者学习网
            <p>林宇</p>iVtHTML5中文学习网 - HTML5先行者学习网
            <p>我个人表示非常喜欢微软新一代的产品……</p>iVtHTML5中文学习网 - HTML5先行者学习网
        </div>iVtHTML5中文学习网 - HTML5先行者学习网
    </div>iVtHTML5中文学习网 - HTML5先行者学习网
</div>

iVtHTML5中文学习网 - HTML5先行者学习网
css:iVtHTML5中文学习网 - HTML5先行者学习网
iVtHTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
iVtHTML5中文学习网 - HTML5先行者学习网
#outsideiVtHTML5中文学习网 - HTML5先行者学习网
{iVtHTML5中文学习网 - HTML5先行者学习网
    height:180px;iVtHTML5中文学习网 - HTML5先行者学习网
    overflow:hidden;iVtHTML5中文学习网 - HTML5先行者学习网
}iVtHTML5中文学习网 - HTML5先行者学习网
#insideiVtHTML5中文学习网 - HTML5先行者学习网
{iVtHTML5中文学习网 - HTML5先行者学习网
    position:relative;iVtHTML5中文学习网 - HTML5先行者学习网
}iVtHTML5中文学习网 - HTML5先行者学习网
#textiVtHTML5中文学习网 - HTML5先行者学习网
{iVtHTML5中文学习网 - HTML5先行者学习网
    width:160px;iVtHTML5中文学习网 - HTML5先行者学习网
    height:160px;iVtHTML5中文学习网 - HTML5先行者学习网
    background:#0000ff;iVtHTML5中文学习网 - HTML5先行者学习网
    padding:10px;iVtHTML5中文学习网 - HTML5先行者学习网
    color:#fff;iVtHTML5中文学习网 - HTML5先行者学习网
}

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

复制代码 代码如下:
iVtHTML5中文学习网 - HTML5先行者学习网
function go(id, d1, px1, val1, d2, px2, val2) {iVtHTML5中文学习网 - HTML5先行者学习网
    $(id).delay(d1);iVtHTML5中文学习网 - HTML5先行者学习网
    $(id).animate({ bottom: px1 }, val1, function () {iVtHTML5中文学习网 - HTML5先行者学习网
        $(id).delay(d2);iVtHTML5中文学习网 - HTML5先行者学习网
        $(id).animate({ bottom: px2 }, val2);iVtHTML5中文学习网 - HTML5先行者学习网
    });iVtHTML5中文学习网 - HTML5先行者学习网
}

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

然后我们在页面加载完成的时候设置一个定时器,来执行我们定义的go函数:iVtHTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
iVtHTML5中文学习网 - HTML5先行者学习网
$(function () {iVtHTML5中文学习网 - HTML5先行者学习网
    timer1 = setInterval(function () {iVtHTML5中文学习网 - HTML5先行者学习网
        go("#inside", 1500, "180px", 1200, 1000, "0px", 2000);iVtHTML5中文学习网 - HTML5先行者学习网
    }, 3000);iVtHTML5中文学习网 - HTML5先行者学习网
});

iVtHTML5中文学习网 - HTML5先行者学习网
这里的参数可以根据需要进行修改,这里我们让定时器每3秒执行一次go函数。iVtHTML5中文学习网 - HTML5先行者学习网
源码基本都贴出来了,有需要源文件的童鞋可以猛击这里下载iVtHTML5中文学习网 - HTML5先行者学习网

 iVtHTML5中文学习网 - HTML5先行者学习网

 

 iVtHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助