天天看点

用CSS3实现未来的Web

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

<a href="http://twitter.com/smashingmag"></a>

用CSS3实现未来的Web

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

请参阅:

<a href="http://www.w3.org/TR/css3-background/#the-border-radius">W3C Working Draft</a>

<a href="http://www.css3.info/preview/rounded-border/">Border-radius on CSS3.info</a>

<a href="http://www.the-art-of-web.com/css/border-radius/">The Art of Web</a>

用CSS3实现未来的Web

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

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.

请参考:

<a href="http://www.w3.org/TR/2002/WD-css3-border-20021107/#the-border-image-uri">W3C Working Draft</a>

<a href="http://www.css3.info/preview/border-image/">Border-image on CSS3.info</a>

<a href="http://ejohn.org/blog/border-image-in-firefox/">Border-image in Firefox</a>

<a href="http://24ways.org/"></a>

用CSS3实现未来的Web

-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 实现透明度(目前的灯箱效果多使用该技巧 - 译者)

<a href="http://www.w3.org/TR/css3-background/#the-box-shadow">W3C Working Draft</a>

<a href="http://www.css3.info/preview/box-shadow/">Box-shadow on CSS3.info</a>

<a href="http://www.w3.org/TR/2003/CR-css3-text-20030514/#text-shadows">W3C Working Draft</a>

<a href="http://www.css3.info/preview/text-shadow/">Text-shadow on CSS3.info</a>

用CSS3实现未来的Web

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).

<a href="http://www.w3.org/TR/css3-color/#rgba-color">W3C Working Draft</a>

<a href="http://www.css3.info/preview/rgba/">RGBA on CSS3.info</a>

<a href="http://www.stevenyork.com/tutorial/pure_css_opacity_and_how_to_have_opaque_children">Pure CSS Opacity</a>

<a href="http://www.taptaptap.com/"></a>

用CSS3实现未来的Web

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

语法如下:

@font-face {  

font-family:'Anivers';  

src: url('/images/Anivers.otf') format('opentype');  

请参阅:

<a href="http://www.webfonts.info/wiki/index.php?title=Fonts_available_for_%40font-face_embedding">Fonts available for font-face embedding</a>

<a href="http://jontangerine.com/log/2008/10/font-face-in-ie-making-web-fonts-work">Font-face in IE, making Web fonts work</a>

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

Internet Explorer: 46% 的 Internet 无法看到这些效果,因此不要将这些东西用于重要的设计。同时保证,在这些效果不起作用的地方,有替代设计可用。

CSS 验证问题: 这些 CSS3 功能并非最终版本,目前不同的浏览器使用不同标签实现这些功能,可能为你的 Style Sheet 带来验证上的问题。

臃肿代码: 因为不同浏览器要使用不同定义语法,最终将导致你的 CSS 代码十分臃肿。

不当的使用: 对这些效果的不当使用,可能带来一些不良后果,阴影效果尤其如此。

<a target="_blank" href="http://www.cnblogs.com/lhb25/p/must-read-links-for-web-designers-and-developers-volume-12.html">Web 前端工程师和设计师必读精华文章推荐</a>

<a href="http://www.cnblogs.com/lhb25//lhb25/archive/2011/07/28/html5-awesome-single-page-sites-inspiration.html" target="_blank">酷!15个精美的 HTML5 单页网站作品欣赏</a>

<a target="_blank" href="http://www.cnblogs.com/lhb25//lhb25/archive/2011/11/22/best-awesome-css3-animation-demos.html">炫!35个让人惊讶的 CSS3 动画效果演示</a>

<a href="http://www.cnblogs.com/lhb25//lhb25/archive/2012/03/02/30-mind-blowing-parallax-scrolling-effect-websites.html" target="_blank">赞!30个与众不同的优秀视差滚动效果网站</a>

<a target="_blank" href="http://www.cnblogs.com/lhb25//lhb25/archive/2012/01/13/25-outstanding-single-page-website-designs.html">靓å!25个优秀的国外单页网站设计作品欣赏</a>

<a target="_blank" href="http://www.cnblogs.com/lhb25//lhb25/archive/2011/08/09/awesome-html5-and-javascript-effects.html">帅!8个惊艳的 HTML5 和 JavaScript 特效</a>

<a href="http://www.cnblogs.com/lhb25//lhb25/archive/2011/06/27/35-exclusive-rainbow-colored-flash-websites.html" target="_blank">顶!35个很漂亮的国外 Flash 网站作品欣赏</a>

<a href="http://www.cnblogs.com/lhb25//lhb25/archive/2011/08/24/outstanding-admin-panels-part-one.html" target="_blank">哇!34个漂亮网站和应用程序后台管理界面</a>

用CSS3实现未来的Web

<a href="http://www.yyyweb.com/go/web" target="_blank">本博客新站点 ◆ 前端里 ◆ 欢迎围观:)</a>

欢迎任何形式的转载,但请务必注明出处。

继续阅读