芒果小站

  1. 全球最具业界良心的主机 - DigitalOcean

    毫无疑问,目前做得最好的主机供应商

    猛击这里查看

  2. 芒果小站目前使用的主机 - DigitalOcean

    客服响应快,随时退款,XEN 架构稳定

    猛击这里查看

  3. 最好的日本东京线路主机 - DigitalOcean

    可选弗里蒙特、达拉斯、亚特兰大、纽瓦克、伦敦、东京机房

    猛击这里查看

  • 1
  • 2
  • 3
切换到精简模式
8

用 CSS3 实现未来的 Web

作者 芒果/分类 代码/发布于 2009-08-05 20:56

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

1. 圆角效果

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

-moz-border-radius: 20px;
-webkit-border-radius: 20px;
border-radius: 20px;

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

-moz-border-radius-topleft: 20px;
-moz-border-radius-topright: 20px;
-moz-border-radius-bottomleft: 10px;
-moz-border-radius-bottomright: 10px;
-webkit-border-top-rightright-radius: 20px;
-webkit-border-top-left-radius: 20px;
-webkit-border-bottom-left-radius: 10px;
-webkit-border-bottom-rightright-radius: 10px;

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

用例: Twitter

请参阅:
W3C Working Draft
Border-radius on CSS3.info
The Art of Web

2. 图形化边界

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

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

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

border-bottom-rightright-image
border-bottom-image
border-bottom-left-image
border-left-image
border-top-left-image
border-top-image
border-top-rightright-image
border-right-image

支持的浏览器:Firefox 3.1,Safari,Chrome

用例:Blog.SpoonGraphics

请参考:
W3C Working Draft
Border-image on CSS3.info
Border-image in Firefox

3. 块阴影与文字阴影

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

-webkit-box-shadow: 10px 10px 25px #ccc;
-moz-box-shadow: 10px 10px 25px #ccc;
box-shadow: 10px 10px 25px #ccc;

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

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

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

用例:24 Ways

请参考:
W3C Working Draft
Box-shadow on CSS3.info
W3C Working Draft
Text-shadow on CSS3.info

4. 使用 RGBA 实现透明效果

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

rgba(200, 54, 54, 0.5);
background: rgba(200, 54, 54, 0.5);
color: rgba(200, 54, 54, 0.5);
color: #000;
opacity: 0.5;

支持的浏览器:Firefox,Safari,Chrome,Opera (opacity) 以及 IE7 (opacity,with fixes)

用例:24 Ways (RGBA)

请参考:
W3C Working Draft
RGBA on CSS3.info
Pure CSS Opacity

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

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

语法如下:

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

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

用例:TapTapTap

请参阅:
Fonts available for font-face embedding
Font-face in IE, making Web fonts work
Web fonts, the next big thing – A List Apart

虽然 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 代码十分臃肿。
不当的使用:对这些效果的不当使用,可能带来一些不良后果,阴影效果尤其如此。

英文原稿:Push Your Web Design Into The Future With CSS3 | Smashing Magazine
翻译整理:用 CSS3 实现未来的 Web | COMSHARP

版权所有,转载请注明出处。
转载自 <a href="http://mangguo.org/push-your-web-design-into-the-future-with-css3/" title="用 CSS3 实现未来的 Web" rel="bookmark">用 CSS3 实现未来的 Web | 芒果小站</a>
如果喜欢这篇文章,欢迎订阅芒果小站以获得最新内容。

已经有 8 条群众意见

  1. 小强 /2009-08-05 22:52

    学习了哈。 回应

    #1
  2. 小强 /2009-08-05 22:55

    做个友链你的做好了。我的 http://www.yehpc.cn 回应

    #2
  3. 我想想 /2009-08-06 13:01

    什么时候,正式推出啊。 回应

    #3
  4. 芒果我想想/2009-08-06 15:21

    很多浏览器已经支持部分 CSS3 的新特性。 回应

    #4
  5. 老饕 /2009-08-06 21:54

    哈哈,做出了的网站一定很酷啊! 回应

    #5
  6. bolo /2009-08-07 21:59

    简单来说,未来的 web 就是 ie 不能支持的 web 回应

    #6
  7. ?
    用 CSS3 实现未来的 Web | zend实验室-java/php学习教程、web前端设计、网站建设、网页设计、网络SEO推广 /2011-07-11 07:33

    […] 转载至:用 CSS3 实现未来的 Web | 芒果小站 分类: html, 其它 标签: 临时 CSS3 基本要素概览13+ 模拟 JavaScript 交互效果的纯 CSS 技术5 款优秀的 CSS 框架使用 CSS3 创建下拉菜单模块化之 HTML CSS 以及图片使用 JavaScript 和 CSS Rotation 的纯 HTML 时钟CSS 左右两栏自适应布局详解 CSS 的优先权基于 YUI 2.8 的层染色褪色效果打造自己的 Reset.css 评论 (0) Trackbacks (0) 发表评论 Trackback […] 回应

    #7
  8. 外贸SEO /2013-01-09 16:48

    css3是比较有前途的在配合上html5就叼堡了 回应

    #8

下面我简单说几句