CSS3下的渐变文字效果实现示例


Posted in HTML / CSS onMarch 02, 2018

一、方法一:借助mask-image属性

如果您手头上的浏览器是Chrome或是Safari,则您可以在demo页面中看到类似下面的效果:

CSS3下的渐变文字效果实现示例

方法一下的文字渐变效果

相应的HTML代码如下:

<h2 class="text-gradient" data-text="天赐美妞">天赐美妞</h2>

与HTML相对应的CSS代码如下:

.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页面中看到类似下面的效果:

CSS3下的渐变文字效果实现示例

方法二下的文字渐变效果

此处实现相对上面要简单些,HTML代码如下:

<h2 class="text-gradient">天赐美妞</h2>

与HTML相对应的CSS代码如下:

.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;
};

CSS代码中关键有用的其实就是最后三行:

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浏览器下有更好的视觉体验效果,何乐而不为呢?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
带有css3动画效果的兼容多浏览器简单导航条示例
Jan 26 HTML / CSS
CSS3属性box-sizing使用指南
Dec 09 HTML / CSS
Css3圆角边框制作代码
Nov 18 HTML / CSS
html5本地存储_动力节点Java学院整理
Jul 12 HTML / CSS
HTML5 Canvas基本线条绘制的实例教程
Mar 17 HTML / CSS
canvas 阴影和图形变换的示例代码
Jan 02 HTML / CSS
html5默认气泡修改的代码详解
Mar 13 HTML / CSS
原生CSS实现文字无限轮播的通用方法
Mar 30 HTML / CSS
CSS3新特性详解(五):多列columns column-count和flex布局
Apr 30 HTML / CSS
纯html+css实现奥运五环的示例代码
Aug 02 HTML / CSS
如何使用 resize 实现图片切换预览功能
Aug 23 HTML / CSS
在CSS中使用when/else的方法
Jan 18 HTML / CSS
CSS3 @keyframes简单动画实现
Feb 24 #HTML / CSS
css3 实现圆形旋转倒计时
Feb 24 #HTML / CSS
css3 仿写阿里云水纹效果的示例代码
Feb 10 #HTML / CSS
纯css3使用vw和vh实现自适应的方法
Feb 09 #HTML / CSS
如何用css3实现switch组件开关的方法
Feb 09 #HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 #HTML / CSS
css3 clip实现圆环进度条的示例代码
Feb 07 #HTML / CSS
You might like
PHP读取数据库并按照中文名称进行排序实现代码
2013/01/29 PHP
php的array数组和使用实例简明教程(容易理解)
2014/03/20 PHP
mac下Apache + MySql + PHP搭建网站开发环境
2014/06/02 PHP
php生成百度sitemap站点地图类函数实例
2014/10/17 PHP
初识laravel5
2015/03/02 PHP
Smarty使用自定义资源的方法
2015/08/08 PHP
js 第二代身份证号码的验证机制代码
2011/05/12 Javascript
Javascript 运动中Offset的bug解决方案
2014/12/24 Javascript
jquery带有索引按钮且自动轮播切换特效代码分享
2015/09/15 Javascript
jQuery实现的仿百度分页足迹效果代码
2015/10/30 Javascript
谈谈js中的prototype及prototype属性解释和常用方法
2015/11/25 Javascript
javascript嵌套函数和在函数内调用外部函数的区别分析
2016/01/31 Javascript
AngularJS实现分页显示数据库信息
2016/07/01 Javascript
JavaScript里 ==与===区别详解
2016/08/16 Javascript
Angular设置title信息解决SEO方面存在问题
2016/08/19 Javascript
jQuery子元素过滤选择器用法示例
2016/09/09 Javascript
详解微信小程序开发之——wx.showToast(OBJECT)的使用
2017/01/18 Javascript
JavaScript与Java正则表达式写法的区别介绍
2017/08/15 Javascript
vue axios 二次封装的示例代码
2017/12/08 Javascript
Vue通过ref父子组件拿值方法
2018/09/12 Javascript
使用weixin-java-miniapp配置进行单个小程序的配置详解
2019/03/29 Javascript
Vue中关闭弹窗组件时销毁并隐藏操作
2020/09/01 Javascript
[48:23]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#1COL VS EG第一局
2016/03/05 DOTA
python同时给两个收件人发送邮件的方法
2015/04/30 Python
Pycharm中使用git进行合作开发的教程详解
2020/11/17 Python
Html5实现iPhone开机界面示例代码
2013/06/30 HTML / CSS
龟牌英国商店:Turtle Wax Brand Store UK
2019/07/02 全球购物
CSMA/CD介质访问控制协议
2015/11/17 面试题
入党积极分子思想汇报范文
2014/01/05 职场文书
毕业生自荐信格式
2014/03/07 职场文书
卫生巾广告词
2014/03/18 职场文书
优秀工会工作者事迹材料
2014/06/02 职场文书
乡镇群众路线教育实践活动整改措施
2014/10/04 职场文书
2015年保卫科工作总结
2015/05/14 职场文书
人生哲理妙语30条:淡写流年,笑过人生
2019/09/04 职场文书
python实现图片九宫格分割的示例
2021/04/25 Python