使用JS配合CSS实现Windows Phone中的磁贴效果

所属分类: 网页制作 / CSS 阅读数: 474
收藏 0 赞 0 分享

Windows Phone的tile设计的美丽对我来说有余音绕梁的效果。我从来不知道优雅的方块盒子布局能给我深刻的印象。因此我尝试在web里用CSS和Jquery去实现这种tile设计。我已尝试Tile Flip动画效果,它能展示两种不同的信息一个在tile的前端而另外一个就在后端。 

Demo Download
201571182711748.png (520×271)

首先我们要为tile创建和下面图片的效果一样的HTML的内容。每个tile包含了两个分别在前后的div。他们都能包含要展示的信息。下面的html代码生成所需的tile布局。
201571182734002.png (248×249)

tile设计包含了CSS的类名

CSS Code复制内容到剪贴板
  1. <div class="container">   
  2.     <div class="tile tile-normal">   
  3.         <div class="front">   
  4.             <img class="icon" src="ie.PNG" />   
  5.         </div>   
  6.        <div class="back">   
  7.             Internet Explorer   
  8.        </div>   
  9.     </div>   
  10.     <div class="container-small">   
  11.         <div class="tile tile-small">   
  12.             <div class="front">1</div>   
  13.             <div class="back">Tile 1</div>   
  14.         </div>   
  15.         <div class="tile tile-small">   
  16.             <div class="front">2</div>   
  17.             <div class="back">Tile 2</div>   
  18.         </div>   
  19.         <div class="tile tile-small">   
  20.             <div class="front">3</div>   
  21.             <div class="back">Tile 3</div>   
  22.         </div>   
  23.         <div class="tile tile-small">   
  24.             <div class="front">4</div>   
  25.             <div class="back">Tile 4</div>   
  26.         </div>   
  27.     </div>   
  28.     <div class="tile tile-wide">   
  29.         <div class="front">   
  30.            Windows Phone Tiles using CSS and jQuery   
  31.         </div>   
  32.         <div class="back">   
  33.            This is a wide tile   
  34.         </div>   
  35.     </div>   
  36. </div>  

CSS关心的是tile的大小和对齐。(请下载源代码来查看)。这里我要对CSS重要部分进行高亮处理,这部分在tile旋转的时候会创建透明师视图。 

CSS Code复制内容到剪贴板
  1. .tile {   
  2.     float:left;   
  3.     font-family'Roboto'sans-serif;   
  4.     font-size:20px;   
  5.     margin-left:2px;   
  6.     margin-top:2px;   
  7.         
  8.     -moz-perspective:500px;   
  9.     -webkit-perspective:500px;   
  10.     -o-perspective:500px;   
  11.     -ms-perspective:500px;   
  12.     perspective:500px;   
  13. }   

下面的JQuery代码关系Tile Flip。这里我为动画使用了 Transit,它是JQuery的一个扩展。它确实是对平滑动画有好处,同时提供大量在我们这种情况下非常需要的易用的技术,这普通易用的技术能让Tile Flip看起来想两块动画。

JavaScript Code复制内容到剪贴板
  1. $(document).ready(function () {   
  2.         
  3.     $(".back").hide();   
  4.         
  5.     $(".tile").mouseenter(function () {   
  6.         $(this).children(".front").transit( {   
  7.             "rotateX":"90deg"  
  8.         },500,"easeInCirc",function () {   
  9.             var back;   
  10.             $(this).hide();   
  11.             back = $(this).siblings(".back");   
  12.             back.css({   
  13.                 "rotateX" : "-90deg"  
  14.             });   
  15.             back.show();   
  16.             back.transit( {   
  17.                 "rotateX":"0deg"  
  18.             },500,"easeOutCirc");   
  19.         });   
  20.             
  21.     });   
  22.         
  23.     $(".tile").mouseleave(function () {   
  24.         $(this).children(".back").transit( {   
  25.             "rotateX" : "90deg"  
  26.         },500,"easeInCirc",function () {   
  27.             var front;   
  28.             $(this).hide();   
  29.             front = $(this).siblings(".front");   
  30.             front.css({   
  31.                 "rotateX" : "-90deg"  
  32.             });   
  33.             front.show();   
  34.             front.transit({   
  35.                 "rotateX" : "0deg"  
  36.             },500,"easeOutCirc");   
  37.         });   
  38.     });   
  39. });  

一开始,所有的图块都是隐藏的,rotateX是90°,前面的部分是可以看到的,rotateX是0°。所有的图块在鼠标指针进入的时候翻过来,在鼠标指针出来的时候又翻回来。 
201571182755614.png (503×243)

 上面的图解释了在鼠标指针进入时调用的函数这个过程是怎么进行的,鼠标指针出来的时候的工作原理和这个差不多。

这个设计使用的是在最新版本的浏览器才有的CSS 远景属性。我已经测试过它了,发现在火狐20.0和chrome26.0上可以运行。最好是你在chrome里有硬件图像渲染。如果你的浏览器不支持远景属性的话,它在正交直线视图上看起来还是有效的。

更多精彩内容其他人还在看

Opera中国的WEB标准课程

网页制作Webjx文章简介:在这篇文章里,我要向大家介绍我和其他很多人花费数月时间开发的一个课程——Web标准课程,该课程旨在向大家提供Web设计和开发的坚实基础,无论读者是谁,此教程完全免费、可访问,并且不需要预备知识。当然,我主要还
收藏 0 赞 0 分享

CSS样式表渐进增强的基本概念

网页制作Webjx文章简介:如果你挠着头想弄清楚优雅降级和渐进增强的区别,我告诉你,这是视角问题。优雅降级和渐进增强都考虑网站在各种设备的各种浏览器上如何良好运转。两者区别的关键在于它们各自关注的焦点,以及这种关注对工作流程的影响
收藏 0 赞 0 分享

简单介绍Web Developer插件制作网页

网页制作Webjx文章简介:Firefox浏览器是一个良好支持W3C标准的开放源代码的浏览器,拥有Linux/Windows/Mac版本。因为Firefox浏览器良好支持W3C标准,所以使用Firefox来调试网页是非常好的。 Firefox浏览器是
收藏 0 赞 0 分享

CSS布局带来的巨大影响:CSS display属性值

网页制作Webjx文章简介:网页元素应用上那些与表格相关的display属性值后,能够模仿出与表格相同的特性。我将会在该文中给大家演示这种方法给CSS布局带来的巨大影响。 应原书编辑要求,先在文章顶部给出链接:《Everything You
收藏 0 赞 0 分享

用div css模拟表格对角线

这只是探讨一种CSS模拟表格对角线的用法,实际在工作中可能觉得这样做有点小题大作,这不是本主题讨论的重点。如果对此深以为然的朋友,请一笑过之 首先声明: 这只是探讨一种CSS模拟表格对角线的
收藏 0 赞 0 分享

IE Firefox在css中的差别 (部分)

1、单位问题 问题:任何距离的数值ie可以不加单位,ff必须要求写单位(0除外) 解决:写全单位如padding:0px; 2、水平居中 问题:div里的内容,ie默认为center,而ff默认left 解决:mairgin:0px auto; 3、高度问题
收藏 0 赞 0 分享

不用js可以实现信息提示效果

[code] <style> body { font:verdena; font-size:14px; color:#000 } h1{ font:verdena; font-size:22px; color:#000 } h2{ font:verdena;
收藏 0 赞 0 分享

CSS解决未知高度的垂直水平居中自适应问题

今天有人问起,晚上试着写出来,供参考; 以下代码兼容主流浏览器IE6、IE7、Firefox、Opera。 从最简单的开始………… 一、如何让一个DIV水平居中? 这个简单不作过多说明! [code] <st
收藏 0 赞 0 分享

CSS cursor 属性 -- 鼠标指针样式效果

取值: [ [<uri> ,]* [ auto | crosshair | default | pointer | move | e-resize | ne-resize | nw-resize | n-resize | se-resize | sw-resize |
收藏 0 赞 0 分享

css 简单区别ie6,ie7,firefox的写法

同一样式里可以这样 [code] margin:17px; FF +margin:17px; IE6 IE7 _margin:17px; IE6 [/code] 按这个顺序,刚好区分开三个浏览器
收藏 0 赞 0 分享
查看更多