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

所属分类: 网页制作 / CSS 阅读数: 512
收藏 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里有硬件图像渲染。如果你的浏览器不支持远景属性的话,它在正交直线视图上看起来还是有效的。

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

CSS配合JavaScript做酷的动态页面效果

  利用CSS配合JavaScript的可以做很多更酷的动态页面效果,在本教程的最后给大家简单介绍一下CSS配合JS的应用。首先,要搞清楚事件和动作的概念。在客户端脚本中,JavaScript 通过对事件进行响应来获得与用户的交互。例如,当用户单击一个按钮或者在某段文字上移动鼠标
收藏 0 赞 0 分享

WEB标准,Web前端开发工程师必备技术列表

  想要打造并拥有一流的Web产品开发团队,在团队成员基础能力上一定要下功夫。对于Web前端产品开发来说,仅仅掌握Web1.0时代简单的"网页套接"是完全不够的。我结合自己的团队配备,特此罗列了Web前端产品工程师所涉及的技能列表如下:   通过许多实际项目,
收藏 0 赞 0 分享

用CSS制作Alpha滤镜测试板

alpha滤镜给制作网页特效提供了较大的创作空间,但由于它控制参数较多,在实际应用时,为了确定一组合适的参数值,不得不反复调整修改,在编辑窗口和预览窗口来回倒腾,甚是麻烦,本文介绍了一种简单的方法。制作一个“Alpha滤镜参数测试板”,在测试板上输入参数
收藏 0 赞 0 分享

非常流行的所谓的气泡窗口

普通的Alt无法自定义风格,而Sweet Titles通过JS脚本与CSS的集合.自定义了这种伪Alt风格. 前一段时间非常流行的,就所谓的气泡窗口(鼠标移到链接处出现的). 我们这里实现的用的是Sweet Titles的插件.显示效果完全由CSS控制.. 先下载Sweet Ti
收藏 0 赞 0 分享

CSS教程:li和ul标签用法举例

LI代码的格式化: A).运用CSS格式化列表符: ul li{ list-style-type:none; } B).如果你想将列表符换成图像,则: ul li{ list-style-type:none; list-style-image: url(/blog/images/
收藏 0 赞 0 分享

CSS教程:CSS中的定位(position)

  使用CSS来定位页面内层的位置,一直是比较难以掌握的事情,很多时候,往往被绝对定位的元素,总是以浏览器的左上角为坐标原点,此时,如果浏览器的大小改变,被定义的层就会偏离设计想要的位置,让人很挠头。   其实,要想控制好层的绝对定位,只要理解CSS中关于定位
收藏 0 赞 0 分享

CSS教程:盒模型(BOX Model)

  如果想熟练掌握DIV和CSS的布局方法,首先要对盒模型有足够的了解。每个HTML元素都可以看作一个装了东西的盒子,盒子里面的内容到盒子的边框之间的距离即填充(padding),盒子本身有边框(border),而盒子边框外和其他盒子之间,还有边界(margin),如图1所示。
收藏 0 赞 0 分享

无延迟翻滚的图形与CSS混合风格按钮

  在一个具有图形背景的按钮中添加CSS风格的文本,这种建立按钮的方法结合了具有CSS翻滚(CSS rollover)标记的开发速度和效率,从而有效地提高按钮外表图像的三维效果。   相比于常规的图形按钮,这些图形/CSS混合按钮可易于建立和载入,因为你只需要为空白按钮外面
收藏 0 赞 0 分享

css里expression实现界面对象的批量控制

用过css样式我们就知道, 可以定义一批对象的class属性来指定同一个样式来统一界面. 但如何统一同类型的对象的事件? 比如:界面有无数个 <img src="**.jpg"> 如何实现鼠标经过此图片, 图片的src变成是**_over.jpg?
收藏 0 赞 0 分享

CSS教程:水平对齐(text-align)

  水平对齐(text-align),用以设定元素内文本的水平对齐方式。   1.语法   text-align具体参数如下: 语法:text-align:left|right|center|justify 说明:设定元素内文本的水平对齐方式。 参数:left:左
收藏 0 赞 0 分享
查看更多