用css3制作纸张效果

2016-02-19 18:18 35 1 收藏

今天图老师小编给大家介绍下用css3制作纸张效果,平时喜欢用css3制作纸张效果的朋友赶紧收藏起来吧!记得点赞哦~

【 tulaoshi.com - Web开发 】

一、中规中矩的效果

所谓中规中矩的效果就是加个投影,贴个胶带什么的。效果如下:
中规中矩的纸张效果 张鑫旭-鑫空间-鑫生活

您可以狠狠地点击这里:中规中矩纸张效果demo

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

这里纸张本身的效果没有什么说头的,就是个CSS3的box-shadow投影效果而已,相关代码如下:

-moz-box-shadow: 0 2px 10px 1px rgba(0, 0, 0, 0.2);-webkit-box-shadow: 0 2px 10px 1px rgba(0, 0, 0, 0.2);box-shadow: 0 2px 10px 1px rgba(0, 0, 0, 0.2);

反而是上面的胶带纸效果有点说头,这些微微倾斜的胶带是CSS写出来的,大部分效果源自CSS3,主要有RGBA显示半透明背景色,box-shadow显示淡淡的投影,transform做旋转效果;元素使用after伪类生成,完整代码如下:

.page:after {width: 180px;height: 30px;content: " ";margin-left: -90px;border: 1px solid rgba(200, 200, 200, .8);background: rgba(254, 254, 254, .6);-moz-box-shadow: 0px 0 3px rgba(0, 0, 0, 0.1);-webkit-box-shadow: 0px 0 3px rgba(0, 0, 0, 0.1);box-shadow: 0px 0 3px rgba(0, 0, 0, 0.1);-moz-transform: rotate(-5deg);-webkit-transform: rotate(-5deg);-o-transform: rotate(-5deg);transform: rotate(-5deg);position: absolute;left: 50%;top: -15px;}

老外似乎很喜欢使用before和after伪类,国外最近的些教程,技术点等经常见到此玩意。我个人感觉有跟风之嫌,就像是狂热的经济泡沫,不需 要太久,大家会冷静下来重新审视这些曾经上手简单,自我感觉不错的方法。由于目前IE6/7不支持before/after类,所以,某种意义上来说,伪 类的使用少了些兼顾IE下显示的烦恼。

关于transform属性,您可以参见我之前的CSS3 Transitions, Transforms和Animation使用简介与应用展示一文,有详细介绍。

二、外翻卷角纸张效果

纸张一般都是有卷角的,所以,我们可以更近一步,模拟卷角效果来使得纸张的感觉更逼真,这里就要借助于投影了,且是曲线投影。关于曲线投影效果,我在之前的CSS3 box-shadow实现纸张的曲线投影效果一文中已经有过介绍。

我们还可以给纸张增加渐变(gradient)效果,以模拟纸张的曲度。
同时,可以给文字增加投影,可以让文字有书写的凹陷感,可以进一步让纸张效果更逼真。

于是,在中规中矩纸张基础上,我们做点小手术,结果得到下面的效果:
卷角,渐变,文字凹陷纸张效果截图 张鑫旭-鑫空间-鑫生活

您可以狠狠地点击这里:渐变卷边纸张效果demo

其中,关于CSS3渐变,您可以参见我之前的CSS gradient渐变之webkit核心浏览器下的使用CSS渐变之CSS3 gradient在Firefox3.6下的使用这两篇文章,目前貌似opera浏览器还不支持CSS3渐变,同时webkit核心下浏览器下的gradient渐变的写法已经开始向FireFox浏览器靠拢了。确实,都是CSS3,有必要搞得五花八门吗?

相关渐变CSS代码如下:

background:-moz-linear-gradient(top, #f4f39e, #f5da41 60%, #fe6);background:-webkit-gradient(linear, 0% 0%, 0% 100%, from(#f4f39e), to(#fe6), color-stop(.6, #f5da41));

在60%的位置有个颜色拐点。

关于弧形的投影,也是使用:before/:after伪类实现的,相关代码如下:

.page:before {-webkit-transform: skew(-15deg) rotate(-5deg);-moz-transform: skew(-15deg) rotate(-5deg);-o-transform: skew(-15deg) rotate(-5deg);transform: skew(-15deg) rotate(-5deg);left: 15px;}.page:after {-webkit-transform: skew(15deg) rotate(5deg);-moz-transform: skew(15deg) rotate(5deg);-o-transform: skew(15deg) rotate(5deg);transform: skew(15deg) rotate(5deg);right: 15px;}.page:before, .page:after {width: 90%;height: 20%;content: ' ';-webkit-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);-moz-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);position: absolute;bottom: 22px;z-index: -1;}

要想查看效果的完整代码,demo页面查看源文件即可,脱光光,一览无遗。

这里的曲线投影卷角效果支持Opera浏览器,如下截图:
Opera浏览器下的卷边效果 张鑫旭-鑫空间-鑫生活

三、带分隔线的卷纸纸张效果

上面的纸张卷角效果是通过曲线投影效果来模拟的,而这里,纸张的卷边效果是纸张真的曲线化了,而且,还是带隔线的纸张效果哦,您可以参见下面的效果截图(Chrome 9):
带分隔线的曲线纸张效果 张鑫旭-鑫空间-鑫生活

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/webkaifa/)

您可以狠狠地点击这里:带分隔线的卷纸纸张效果demo

这里,Firefox浏览器下的纸张隔线使用的是重复渐变(Repeating Gradients)实现的,这个在上面提到的CSS渐变之CSS3 gradient在Firefox3.6下的使用一文中的第五部分又介绍,对于webkit浏览器,使用的是background-size实现的。实际上,Firefox3.6+已经支持background-size属性了(-moz-background-size)(参见这里), 所以,对于Firefox浏览器,这里使用重复渐变与渐变+background-size是等效的。在FireFox4以及IE9浏览器中 background-size属性已经没有私有属性了,Opera浏览器在9.5版本时候就已经支持background-size属性了,但是存在一 些bug。

这里分隔线实现的相关CSS如下:

background:-moz-repeating-linear-gradient(top,#fcf59b,#fcf59b 29px,#81cbbc 30px);background:-webkit-gradient(linear,left top, left bottom,from(#81cbbc),color-stop(2%, #fcf59b));background:repeating-linear-gradient(top,#fcf59b,#fcf59b 29px,#81cbbc 30px);-webkit-background-size: 100% 30px;

而对于曲边的实现,使用的是border-radius圆角,这里展示下示意的代码:

border-bottom-left-radius: 20px 500px;border-bottom-right-radius: 500px 30px;border-top-right-radius: 5px 100px;

当然,FireFox浏览器下的写法不是如此,其bottom, left是连起来的,而不是-分隔,这里仅仅是示意,这里的微曲线是如何实现的。相信看到上面的代码就知道意思了,这里就不啰嗦了。

还有其他些细节,如如何控制行高让文字与隔线一一对应,这些您要是有兴趣可以去demo页面,通过查看元素等方法一看究竟。

四、参考文章

Let’s Create Paper with CSS
I’m a CSS3 sticky note!
CSS Sticky Notes
background-size | -moz-background-size

五、最后点老生常谈

难免的,本文的重点在于CSS3,所以就本文而言,IE6/IE7/IE8浏览器就是过来打酱油的,且三个纸张效果从一而终,都是下面这副模样:
IE7浏览器下的纸张效果截图 张鑫旭-鑫空间-鑫生活

虽然没有透明胶效果,没有投影,没有卷边,更没有分隔线,但是,就功能上来讲,一点都不影响使用。所以,无论你是渐进增强还是退求其次,纸张投影效果在实际项目中的应该也不是不可以的,这就要看个人和团队的抉择了。

其实对于IE浏览器,我们可以借助于javascript,添加部分效果,例如透明胶带的创建,曲线投影效果等。原理如 下::before/:after伪类创建的元素在IE下使用javascript创建,旋转投影等都可以借助IE的滤镜实现。但是,还是要看个人和团 队,愿不愿意花这个成本了。

来源:http://www.tulaoshi.com/n/20160219/1617197.html

延伸阅读
  最近闲来无事,上W3C转了一圈,粗略地浏览了一下尚未发布的CSS3,虽然还未被W3C正式发布出来,但还是能从已有的资料中窥出一些端倪,一个很明显的特征,CSS3制订得越来越细致了,某些细节之处完全超乎你所能想象的到的范围。 在这里不提及CSS3的语法,因为对于目前尚未有软件支持的CSS3,任何语法的探讨都像是空中楼...
标签: Web开发
CSS3动画尽管目前只有webkit内核的一些浏览器才支持,但是作为一个前端从业者,应该有长远的目光,尽早的去熟悉,今天就用CSS3做了一个照片长廊的应用,效果图: Demo地址: 请使用safari或者chrome猛击 制作步骤如下: 1.首先我们铺设一个渐变的背景色: DaimaRen.cn © 2009-2010 by Tomie Zhang background: -webkit-gradient(...
标签: Web开发
尽管CSS3的诸多新特性还不被很多浏览器支持,或者说支持的不好。但作为一个前端开发人员,你总不能等到所有浏览器都完美支持它的时候再去学习。 CSS3到底给我们带来了哪些新特性呢?简单的说,CSS3把很多以前需要使用图片和脚本来实现的效果,只需要短短几行代码就能搞定。比如圆角,图片边框,文字阴影和盒阴影等。CSS3不仅能简化前端开发...
说起CSS3的新特性,就不得不提到 Media Queries 。本文比较详细,所以很多实际中用不到。所以如果只是想简单了解Media Queries,推荐参考 CSS3 Media Queries 。 CSS2.1定义了 Media 的部分,包括类型、组别和规则等。CSS并非为了显示器而创造,而是应用于各种各样的媒体,比如常见的显示器,越来愈多的手持设备,可能略显过时的电视机等等。 ...
标签: Web开发
说起CSS3的新特性,就不得不提到 Media Queries 。 本文比较详细,所以很多实际中用不到。所以如果只是想简单了解Media Queries,推荐参考 CSS3 Media Queries 。 CSS2.1定义了 Media 的部分,包括类型、组别和规则等。CSS并非为了显示器而创造,而是应用于各种各样的媒体,比如常见的显示器,越来愈多的手持设备,可能略显过...

经验教程

455

收藏

55
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部