用 CSS3 实现未来的 Web

CSS 3 + HTML 5 是未来的 Web,它们都还没有正式到来,虽然不少浏览器已经开始对它们提供部分支持。本文介绍了 5 个 CSS3 技巧,可以帮你实现未来的 Web,不过,这些技术不应该用在正式的客户项目,它们更适合你的个人博客站点,Web 设计社区,或者不会有客户向你投诉的场合。

1. 圆角效果

CSS3 新功能中最常用的一项是圆角效果,标准 HTML 方块对象是90度方角的,CSS3 可以帮你实现圆角。

  1. -moz-border-radius: 20px;  
  2. -webkit-border-radius: 20px;  
  3. border-radius: 20px;  

甚至单个角也可以实现圆角,不过 Mozilla 和 Webkit 的语法稍有不同。

  1. -moz-border-radius-topleft: 20px;  
  2. -moz-border-radius-topright: 20px;  
  3. -moz-border-radius-bottomleft: 10px;  
  4. -moz-border-radius-bottomright: 10px;  
  5. -webkit-border-top-rightright-radius: 20px;  
  6. -webkit-border-top-left-radius: 20px;  
  7. -webkit-border-bottom-left-radius: 10px;  
  8. -webkit-border-bottom-rightright-radius: 10px; 

所支持的浏览器:Firefox, Safari , Chrome
用例: Twitter

请参阅:

 

 2. 图形化边界

顾名思义,图形化边界就是允许使用图片作为对象的边界,语法如下:

  1. border: 5px solid #cccccc;  
  2. -webkit-border-image: url(/images/border-image.png) 5 repeat;  
  3. -moz-border-image: url(/images/border-image.png) 5 repeat;  
  4. border-image: url(/images/border-image.png) 5 repeat; 

这里,border: 5px   设定了边界的宽度,然后,每个边界的图片定义告诉浏览器,使用图片的多大一部分来充当边界。边界图片还可以针对每一条边单独设置:

  1. border-bottom-rightright-image  
  2. border-bottom-image  
  3. border-bottom-left-image  
  4. border-left-image  
  5.    border-top-left-image  
  6.    border-top-image  
  7.    border-top-rightright-image  
  8.    border-right-image  

支持的浏览器: Firefox 3.1, Safari , Chrome.
用例: Blog.SpoonGraphics.

请参考:

 

3. 块阴影与文字阴影

阴影效果曾让 Web 设计师既爱又恨,现在,有了 CSS3,你不再需要 Photoshop,已经有网站在使用这个功能了,如 24 Ways website.

  1. -webkit-box-shadow: 10px 10px 25px #ccc;  
  2. -moz-box-shadow: 10px 10px 25px #ccc;  
  3. box-shadow: 10px 10px 25px #ccc; 

前两个属性设置阴影的 X / Y 位移,这里分别是 10px,第3个属性定义阴影的虚化程度,最后一个设置阴影的颜色。文字阴影也可以这样设置:

  1. text-shadow: 2px 2px 5px #ccc; 

支持的浏览器:Firefox 3.1, Safari, Chrome (只支持 Box 阴影) ,Opera (只支持文字阴影).前3个数字表示红绿蓝三色的值,最后一个值代表透明度,另外,我们还可以使用 opacity 实现透明度(目前的灯箱效果多使用该技巧 - 译者)

用例: 24 Ways.

请参考:

 

4. 使用 RGBA 实现透明效果

目前,Web 设计中的透明效果主要靠 PNG 图片实现(但在 IE 浏览器支持得并不好 - 译者),在 CSS3,可以直接实现透明效果。

  1. rgba(200, 54, 54, 0.5);  
  2. background: rgba(200, 54, 54, 0.5);  
  3. color: rgba(200, 54, 54, 0.5); 

 

  1. color: #000;  
  2. opacity: 0.5; 

支持的浏览器: Firefox, Safari, Chrome, Opera (opacity) 以及 IE7 (opacity, with fixes).
用例: 24 Ways (RGBA).

请参考:

5. 使用 @Font-Face 实现定制字体

Web 设计中有几种字体是比较安全的,如 Arial,Helvetica, Verdana, Georgia, Comic Sans (中文的,一般来说宋体是唯一安全的 - 译者),现在,使用 CSS3 的 @font-face 可以自己指定字体,不过因为牵扯到版权问题,实际能用的字体也是有限的 (另外,体积庞大的中文字体也是一个不好解决的问题 - 译者)。

语法如下:

  1. @font-face {  
  2. font-family:'Anivers';  
  3. src: url('/images/Anivers.otf') format('opentype');  

支持的浏览器: Firefox 3.1, Safari, Opera 10 and IE7 (需要一番周折,如果你不怕麻烦,可以在 IE 实现这个功能,请参考: make font-face work in IE )

用例: TapTapTap.

请参阅:

虽然 CSS3 尚在开发中,上面提到的这些功能已经可以在部分浏览器中使用了,尤其是 Safari。不幸的是,Safari 并非主流浏览器。

Firefox 目前拥有大量用户基础,另外,即将推出的 Firefox 3.1 支持不少 CSS3 效果,因为 Firefox 用户的升级积极性很高,因此,会有不少用户可以提前体验 CSS3 的新功能。

Google Chrome 今年刚刚发布,它基于 Webkit 引擎,因此和 Safari 很相似,因为 Safari 主要用于 Mac 市场,Chrome 可以正好弥补 Windows 市场的空缺。

根据统计数据,2008年11月止,44.2% 的用户使用 Firefox, 3.1% 使用 Chrome, 2.7% 使用 Safari,意味着 CSS3 的部分功能已经可以支持近半 Internet 用户,而在 Web 设计圈子,这个比例可能更高,大约有 73.6% (Blog.SpoonGraphics 提供的数据)

6. 负面因素

上面讲述的这些 CSS3 功能会给你的网站带来出色的效果,但仍有一些负面的因素必须考虑:

  • Internet Explorer: 46% 的 Internet 无法看到这些效果,因此不要将这些东西用于重要的设计。同时保证,在这些效果不起作用的地方,有替代设计可用。
  • CSS 验证问题: 这些 CSS3 功能并非最终版本,目前不同的浏览器使用不同标签实现这些功能,可能为你的 Style Sheet 带来验证上的问题。
  • 臃肿代码: 因为不同浏览器要使用不同定义语法,最终将导致你的 CSS 代码十分臃肿。
  • 不当的使用: 对这些效果的不当使用,可能带来一些不良后果,阴影效果尤其如此。

 

本文国际来源:http://www.smashingmagazine.com/2009/01/08/push-your-web-design-into-the-future-with-css3/
中文翻译来源:COMSHARP CMS 官方网站(35公里译)





评论
hellfire|2009/11/6 10:10:50 
臃肿代码: 因为不同浏览器要使用不同定义语法,最终将导致你的 CSS 代码十分臃肿。
因为这点,真的不能称之为标准
 
发表评论


用户


评论(不超过1000字)


 3 x 7 = ? 请将左边的算术题的结果填写到左边的输入框  


  发送给朋友| 打印友好
7 x 12 小时服务热线
0532 - 83669660
微信: comsharp
QQ: 13885509
QQ: 592748664
Skype: comsharp