在web前端开发过程中,UI设计师经常会设计一些带渐变文字的设计图,在以前我们只能用png的图片来代替文字,但是今天有了css3我们就可以实现渐变文字了。
借助mask-image属性
如果你手头上的浏览器是Chrome或是Safari,则你可以在demo页面中看到类似下面的效果:
HTML代码如下:
1 | <h2 class="text-gradient" data-text="码云笔记">码云笔记</h2> |
CSS代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | .text-gradient { display: inline-block; font-family: '微软雅黑'; font-size: 10em; position: relative; } .text-gradient[data-text]::after { content: attr(data-text); color: green; position: absolute; left: 0; z-index: 2; -webkit-mask-image: -webkit-gradient(linear, 0 0, 0 bottom, from(#ff0000), to(rgba(0, 0, 255, 0))); } |
从CSS代码可以看出,效果的实现除了“content内容生成技术”以外,主要是使用了mask-image属性,内容则是“webkit核心浏览器下的渐变”了。
background-clip + text-fill-color下的实现
Chrome或是Safari浏览器下,我们可以在demo页面中看到类似下面的效果:
HTML代码如下:
1 | <h2 class="text-gradient">码云笔记</h2> |
CSS代码如下:
1 2 3 4 5 6 7 8 9 | .text-gradient { display: inline-block; color: green; font-size: 10em; font-family: '微软雅黑'; background-image: -webkit-gradient(linear, 0 0, 0 bottom, from(rgba(0, 128, 0, 1)), to(rgba(51, 51, 51, 1))); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }; |
关键代码是后面三行:
1 2 3 | background-image: -webkit-gradient(linear, 0 0, 0 bottom, from(rgba(0, 128, 0, 1)), to(rgba(51, 51, 51, 1))); -webkit-background-clip: text; -webkit-text-fill-color: transparent; |
此方法虽然使用的CSS属性相对多些,但是结构简单,易于控制,颜色的选取与控制也更精确,理解上也更容易理解。我个人是推荐使用方法二的。
由于目前text-fill-color与mask-image属性貌似就webkit核心的浏览器支持,所以两个demo页面只能在Chrome浏览器或是Safari浏览器下才能看到渐变效果。Firefox浏览器下纯色,IE下就更不用说了。
结束语
在前端开发中文字渐变效果对于项目来说起到装饰性的功能,所以,我们在实际项目中可以大胆使用的。试想,在不影响原来功能的基础上,我们只需要几行CSS代码,就可以让占有率愈来愈高的Chrome浏览器下有更好的视觉体验效果,达到了井上添花的功效,何乐而不为呢?
未经允许不得转载:码云笔记 » CSS3实现渐变文字效果
评论抢沙发