• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 浅析CSS中怎么实现线性渐变(linear-gradient)

浅析CSS中怎么实现线性渐变(linear-gradient)

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了CSS线性渐变,linear-gradient等相关知识,希望对您有所帮助

CSS中怎么实现线性渐变?下面本篇文章给大家介绍一下CSS线性渐变函数linear-gradient()的使用方法,并聊聊线性渐变的多种应用,希望对大家有所帮助!


浅析CSS中怎么实现线性渐变(linear-gradient)


linear-gradient

1. 语法

linear-gradient([[to <direction>|<angle>],]? <color stop?>, <color stop?>[, ...]?)

-webkit-linear-gradient([[<direction>|<angle>],]? <color stop?>, <color stop?>[, ...]?)

这2种在使用方式和表现形式上都有所不同,使用direction时,前者要带to, 后者不带;使用angle时,表现不一致。


1)默认

二者默认都是从上到下

background-image:linear-gradient(#00ffff, #ff1493, #006699);background-image:-webkit-linear-gradient(#00ffff, #ff1493, #006699)

浅析CSS中怎么实现线性渐变(linear-gradient)

2)<direction>: [left|right]|[top|bottom]的使用

二者表现方向相反

background-image:linear-gradient(to left, #00ffff, #ff1493, #006699);background-image:-webkit-linear-gradient(left, #00ffff, #ff1493, #006699);

浅析CSS中怎么实现线性渐变(linear-gradient)

background-image:linear-gradient(to left top, #00ffff, #ff1493, #006699);background-image:-webkit-linear-gradient(left top, #00ffff, #ff1493, #006699);

浅析CSS中怎么实现线性渐变(linear-gradient)

3)<angle>的使用

度数与方向的对应关系。-webkit-与之对应的方向则为450°-angle


浅析CSS中怎么实现线性渐变(linear-gradient)

background-image:linear-gradient(275deg, #ff1493, #000000, #006699);background-image:-webkit-linear-gradient(175deg, #ff1493, #000000, #006699);

450°-175°=275°,所以二者表现一致,如下图:

浅析CSS中怎么实现线性渐变(linear-gradient)

4)<color stop> = <color [percentage|length]>的使用

stop可使用百分比,也可以使用具体值,表示这种颜色在此位置达到饱和

background-image:linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);background-image:-webkit-linear-gradient(to right, #ff1493 10%, #000000 40%, #006699 60%);

浅析CSS中怎么实现线性渐变(linear-gradient)

从上图可以看出颜色变化过程:

0% --> 10%: #ff1493一直处于饱和

10% --> 40%: #ff1493渐变为#000000, 在40%处,#000000达到饱和

40% --> 60%: #000000渐变为#006699, 在60%处,#006699达到饱和

60% --> 100%: #006699一直处于饱和

利用这一特性,可以绘制出条纹

background-image:linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);background-image:-webkit-linear-gradient(to right, #ff1493 33%, #000000 33%, #000000 66%, #006699 66%);

浅析CSS中怎么实现线性渐变(linear-gradient)

注:stop还可以同时设置2个值, 如linear-gradient(to right, #ff1493 0% 33%, #000000 33% 66%, #006699 66% 100%);-webkit-linear-gradient(to right, #ff1493 33%, #000000 33% 66%, #006699 66% 100%);,效果与上图一致。

若后者的值小于前者,以前者为准,如下20px小于60px,实际按60px显示,效果如下图:

background-image:linear-gradient(right, #ff1493 60px, #000000 20px);background-image:-webkit-linear-gradient(right, #ff1493 60px, #000000 20px);

浅析CSS中怎么实现线性渐变(linear-gradient)

扩展1:渐变中心

默认是2种颜色的中心,但是我们可以设置其渐变中心

/* 3种颜色平分,渐变中心为1/3和2/3处 */background-image:linear-gradient(to right, #ff1493, #000000, #006699); /* 渐变中心在10%和20%处 */background-image:linear-gradient(to right, #ff1493, 10%, #000000, 20%, #006699);

注:-webkit-linear-gradient不支持此用法

浅析CSS中怎么实现线性渐变(linear-gradient)

扩展2: repeating-linear-gradient

我们可以使用属性这个绘制重复的色块

background-image:repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px);background-image:-webkit-repeating-linear-gradient(0deg, #ff1493, #000000 10px, #006699 20px)

浅析CSS中怎么实现线性渐变(linear-gradient)

2、常用样式

(1)多色星空

background-image:    linear-gradient(45deg, rgba(255, 0, 76, 0.7), rgba(0, 0, 255, 0) 80%),    linear-gradient(135deg, rgba(106, 0, 128, 1), rgba(0, 128, 0, 0) 80%),    linear-gradient(225deg, rgba(0, 255, 255, 1), rgba(0, 255, 255, 0) 80%),    linear-gradient(315deg, rgba(255, 192, 203, 0.7), rgba(255, 192, 203, 0) 80%);

同时设置多个值,让整个背景色看起来比较绚丽

浅析CSS中怎么实现线性渐变(linear-gradient)

(2)格子图案

background-image:    repeating-linear-gradient(0deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),    repeating-linear-gradient(90deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);     background-image:    repeating-linear-gradient(45deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px),    repeating-linear-gradient(135deg, rgba(0, 255, 255, 0.3) 0px 5px, transparent 5px 10px);

利用颜色与透明色交替渲染

浅析CSS中怎么实现线性渐变(linear-gradient)

(3)边框渐变

<div id="wrap"></div><style> #wrap {    width: 180px;    height: 40px;    border: 5px solid transparent;    border-image: linear-gradient(45deg, aqua, pink, purple) 1;} </style>

内部背景透明,但是不支持设置border-radius

浅析CSS中怎么实现线性渐变(linear-gradient)

<div id="wrap"></div><style> #wrap {    width: 180px;    height: 40px;    border: 5px solid transparent;    border-image: linear-gradient(45deg, aqua, pink, purple) 1;    clip-path: inset(0 round 5px);} </style>

注:可以使用clip-path裁剪出圆角, 但是这种方式不适用于角度较大的圆角

浅析CSS中怎么实现线性渐变(linear-gradient)

<div id="wrap">    <div id="content"></div></div><style>#wrap {    width: 180px;    height: 40px;    border-radius: 20px;    background: #FFF;    position: relative;} #wrap::before {    content: '';    position: absolute;    left: -5px;    right: -5px;    top: -5px;    bottom: -5px;    background-image: linear-gradient(45deg, aqua, pink, purple);    border-radius: 25px;    z-index: -1} /*或者*/ #wrap {    width: 180px;    height: 40px;    border-radius: 20px;    background: #FFF;    position: relative;    border: 5px solid transparent;    background-origin: border-box;    background-image: linear-gradient(#FFF, #FFF), linear-gradient(45deg, aqua, pink, purple);    background-clip: padding-box, border-box;} /*或者*/ #wrap {    width: 180px;    height: 50px;    border: 5px solid transparent;    border-radius: 25px;    background-image: linear-gradient(45deg, aqua, pink, purple);    background-origin: border-box;} #content {    width: 100%;    height: 100%;    border-radius: 20px;    background: #FFF;} </style>

这几种方式都能做到圆角渐变边框,但是无法做到内部背景透明

浅析CSS中怎么实现线性渐变(linear-gradient)

(4)文字渐变

<div id="wrap"> Darker CMJ</div><style>#wrap {    font-size: 40px;    line-height: 40px;    font-weight: bold;    background-clip: text;    -webkit-background-clip: text;    // color: transparent;    -webkit-text-fill-color: transparent;    background-image: linear-gradient(45deg, aqua, pink, purple);}</style>

background-clip规定背景的绘制区域,我们设置其值为text,就是在文字区域绘制,然后将文字color或者-webkit-text-fill-color设置为透明色,渐变区域就能显示出来了

浅析CSS中怎么实现线性渐变(linear-gradient)

好了,over,第一次写文章,希望能坚持下去=.=

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅析CSS中怎么实现线性渐变(linear-gradient)

相关文章

  • 2022-04-29Photoshop创建梦幻迷离的彩虹背景
  • 2022-04-29vue2&vue3数据响应式原理分析及手动实现(实例详解)
  • 2022-04-29PHP+Mysql+jQuery找回密码
  • 2022-04-29织梦DedeCMS时隔多年,终于更新了!(DedeCMSV5.7版下载)
  • 2022-04-29一文讲解Wordpress插件怎么查找并安装
  • 2022-04-29PhotoShop绘制简单的小铃铛APP Icon图标制作教程
  • 2022-04-29Nginx下怎么部署php项目
  • 2022-04-29详细介绍mysql忘记密码的解决方案及修改密码的三种方式
  • 2022-04-29thinkphp的钩子的两种配置和两种调用方法
  • 2022-04-29javascript如何删除数组里的某个元素

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • 帝国CMS后台添加关键字时自动复制到TAGS(同步更新)的方法
    • Thinkphp自带分页类样式转Bootstrap分页样式
    • Photoshop使用3D工具制作超酷的金属立体字
    • 如何禁用WordPress5.5自带Sitemap
    • Photoshop制作立体效果的像素艺术字
    • MYSQL有哪些常用基本SQL语句
    • 关键词选择技巧之长尾关键词法
    • 如何增加外链,增加外链方法汇总
    • 聊聊Bootstrap5中的断点与容器
    • 帝国CMS结合JS自定义手机端内容分页样式

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有