广告
返回顶部
首页 > 资讯 > 前端开发 > html >CSS中的线性渐变linear-gradient怎么用
  • 343
分享到

CSS中的线性渐变linear-gradient怎么用

2024-04-02 19:04:59 343人浏览 薄情痞子
摘要

这篇文章给大家介绍CSS中的线性渐变linear-gradient怎么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在css3出现之前,渐变效果只能通过图形软件设计图片来实现,可拓展

这篇文章给大家介绍CSS中的线性渐变linear-gradient怎么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

css3出现之前,渐变效果只能通过图形软件设计图片来实现,可拓展性差,还影响性能。如今已经进入CSS3标准的渐变可以很轻松的完成渐变效果。渐变实际上分为线性渐变和径向渐变两种,本文介绍线性渐变。

定义  

渐变实际上是两种或多种颜色之间的平滑过渡。而线性渐变是多种颜色沿着一条直线(称为渐变线)过渡。渐变的实现由两部分组成:渐变线和色标。渐变线用来控制发生渐变的方向;色标包含一个颜色值和一个位置,用来控制渐变的颜色变化。浏览器从每个色标的颜色淡出到下一个,以创建平滑的渐变,通过确定多个色标可以制作多色渐变效果。

[注意]safari4-5、iOS3.2-4.3、Android2.1-3只支持线性渐变,且需要添加-WEBkit-;safari5.1-6、ioS5.1-6.1、android4-4.3支持线性和径向渐变,且需要添加-webkit-;IE10+及其他高版本浏览器支持标准写法

CSS Code复制内容到剪贴板

<linear-gradient> = linear-gradient([ [ <angle> | to <side-or-corner> ] ,]? <color-stop>[, <color-stop>]+)   
<side-or-corner> = [left | rightright] || [top | bottombottom]

渐变线  
渐变线从渐变框中心向两个方向进行拓展,起点和终点是渐变线与经过渐变框的一个角的垂直线的相交点

CSS中的线性渐变linear-gradient怎么用

渐变的第一个参数用于指定渐变线,默认是to bottom。有两种方式指定渐变线方向

【1】使用角度

0deg表示沿着元素的中心线由下向上的方向(类似于y轴),且正角度表示顺时针旋转

[注意]对于-webkit-旧版本浏览器,如windows系统下的safari浏览器来说,0deg表示沿着元素中心线从左向右的方向(类似于x轴),且正角度表示逆时针旋转

所以-webkit-旧版本浏览器与标准浏览器的之间线性渐变的角度关系为

-webkit-浏览器 = 90deg - 标准浏览器
相当于-webkit-linear-gradient(90deg,red,blue) = linear-gradient(0deg,red,blue)

[注意]对于webkit内核的浏览器来说,使用javascript改变元素的样式。当带-webkit-的私有样式和不带-webkit-的标准样式同时存在的时候,并不一定是后面覆盖前面。所以如果两种写法产生的效果相同,但参数不同时,要使用浏览器识别来分别写不同的情况。

【2】使用关键字

CSS Code复制内容到剪贴板


  1. to top -> 0deg   
    to rightright -> 90deg   
    to bottombottom -> 180deg   
    to left -> -90deg(或270deg)   
    to top left -> -45deg(或315deg)   
    to top rightright -> 45deg   
    to bottombottom left -> -135deg(或225deg)   
    to bottombottom rightright -> 135deg

[注意]window系统的safari浏览器并不支持'to'加方向的关键字,如to left。它只支持方向关键字,如left。当然了left 和 to left 方向是正好相反的

色标  
浏览器对于色标并没有默认值,且必须设置至少两个色标。色标由颜色和位置组成。颜色使用任何一种颜色模式都可以,而位置可以使用百分比或数值。

[注意]颜色的位置也可以设置负值

【1】必须是颜色在前,位置在后

JavaScript Code复制内容到剪贴板

  1. //正确   

  2. background-image: linear-gradient(red 0%,blue 100%);   

  3. //错误   

  4. background-image: linear-gradient(0% red,100% blue);  

【2】位置可以省略,浏览器默认会把第一个颜色的位置设置为0%,把最后一个颜色的位置设置为100%

JavaScript Code复制内容到剪贴板

  1. background-image: linear-gradient(red 0%,blue 100%);   

  2. //等价于上一个   

  3. background-image: linear-gradient(red,blue);  

【3】若渐变只有两种颜色,且第一个颜色的位置设置为n%,第二个颜色的位置设置为m%。则浏览器会将0%-n%的范围设置为第一个颜色的纯色,n%-m%的范围设置为第一个颜色到第二个颜色的过渡,m%-100%的范围设置为第二个颜色的纯色

CSS Code复制内容到剪贴板

  1. background-image: linear-gradient(red 30%,blue 60%);   

  2. //等价于上一个   

  3. background-image: linear-gradient(red 0%,red 30%,blue 60%,blue 100%);  

【4】若渐变颜色没有指定位置,则它们会均匀分布

CSS Code复制内容到剪贴板

  1. background-image: linear-gradient(red,yellow,green,blue);  

【5】若多色占据同一个位置,例a、b、c三色均占据n%这一位置,则0%-n%为前一种颜色与a颜色的颜色渐变;然后是n%-n%的a颜色与c颜色的颜色突变;n%-100%是c颜色与后一种颜色的颜色渐变。因此,中间的b是无用的

CSS Code复制内容到剪贴板

  1. background-image: linear-gradient(red,yellow 50%,white 50%,black 50%,blue);   

  2. //等价于上一个   

  3. background-image: linear-gradient(red,yellow 50%,black 50%,blue);  

重复渐变  
重复渐变可以实现线性渐变的重复效果,使色标在渐变线方向上无限重复,实现一些特殊的效果
[注意]只有当首尾两颜色位置不在0%或100%时,重复渐变才生效

CSS Code复制内容到剪贴板

  1. background-image: -webkit-repeating-linear-gradient(blue 20%,green 50%);   

  2. background-image: repeating-linear-gradient(blue 20%,green 50%);  

纸张效果

使用重复渐变可以实现横线纸张效果  

CSS Code复制内容到剪贴板

  1. div{   
        height: 200px;   
        width:200px;   
        font: 14px/20px '宋体';   
        text-indent: 2em;   
        background-image: -webkit-repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);   
        background-image: repeating-linear-gradient(#f9f9f9,#f9f9f9 9%,#ccc 10%);   
    }

 多背景

使用多背景属性,利用带有透明度的渐变颜色给图片添加渐变的透明效果

CSS Code复制内容到剪贴板

  1. background: linear-gradient(rgba(255,255,255,0),rgba(255,255,255,0.8)),url('Http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/img1.gif');  

应用场景  

在CSS样式中,渐变相当于背景图片,在理论上可在任何使用url()值的地方采用。比如最常见的background-image、list-style-image以及border-image。但目前为止,仅在背景图片中得到完美的支持

【1】background-image

CSS Code复制内容到剪贴板

  1. background-image: -webkit-linear-gradient(pink,lightblue,lightgreen);   

  2. background-image: linear-gradient(pink,lightblue,lightgreen);  

[注意]渐变框的大小由background-size决定,默认是padding box

【2】list-style-image

CSS Code复制内容到剪贴板

  1. list-style-image: -webkit-linear-gradient(red,blue);   

  2. list-style-image: linear-gradient(red,blue);   

  3. font-size: 50px;  

[注意]渐变框的大小由font-size决定,默认是1em

[注意]firefox不支持在list-style-image中设置

  • 我是文字

  • 【3】border-image

    CSS Code复制内容到剪贴板

    1. -webkit-border-image:  -webkit-linear-gradient(black,green) 1/10px;       

    2. border-image:  linear-gradient(black,green) 1/10px;  

    [注意]渐变框的大小由borer-width决定,safari浏览器始终实现的都是带有fill参数的表现

    IE兼容  

    IE9-浏览器并不支持该属性,但可以使用IE准专有的滤镜语法来实现兼容

    CSS Code复制内容到剪贴板

    1. filter: progid:DXImageTransfORM.Microsoft.gradient(GradientType=0, startColorstr='#color', endColorstr='#color');GradientType代表渐变线方向,0为垂直(默认),1为水平   

    2. #color代表色标,格式是#aarrggbb,其中aa为透明度,rrggbb为rgb模式的颜色   


    3. startColorstr的默认值是#ff0000ff    

    4. endColorstr的默认值是#ff000000  

    [注意]由于IE滤镜只支持首尾两个位置,且方向只可以为垂直和水平,所以有很大的局限性

    CSS Code复制内容到剪贴板

    1. filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#ff0000ff', endColorstr='#ffff00ff');  

    CSS中的线性渐变linear-gradient怎么用


关于CSS中的线性渐变linear-gradient怎么用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: CSS中的线性渐变linear-gradient怎么用

本文链接: https://www.lsjlt.com/news/81364.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • CSS中的线性渐变linear-gradient怎么用
    这篇文章给大家介绍CSS中的线性渐变linear-gradient怎么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在CSS3出现之前,渐变效果只能通过图形软件设计图片来实现,可拓展...
    99+
    2022-10-19
  • CSS中线性渐变linear-gradient属性的示例分析
    小编给大家分享一下CSS中线性渐变linear-gradient属性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2022-10-19
  • css中的linear-gradient()怎么使用
    这篇文章主要介绍“css中的linear-gradient()怎么使用”,在日常操作中,相信很多人在css中的linear-gradient()怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2022-10-19
  • CSS3中linear-gradient线性渐变生成加号和减号的示例分析
    这篇文章主要为大家展示了“CSS3中linear-gradient线性渐变生成加号和减号的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“CSS3中lin...
    99+
    2022-10-19
  • 怎么用CSS3中的gradient属性做出背景渐变效果
    小编给大家分享一下怎么用CSS3中的gradient属性做出背景渐变效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!   浏览器支持两种类型的渐变:   linear,用linear...
    99+
    2022-10-19
  • CSS怎么实现线性渐变效果
    这篇文章将为大家详细讲解有关CSS怎么实现线性渐变效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   代码示例如下:   <!DOCTYPE>   ...
    99+
    2022-10-19
  • css3中怎么实现线性渐变和径向渐变
    css3中怎么实现线性渐变和径向渐变,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 线性渐变:i...
    99+
    2022-10-19
  • web中怎么用线性渐变实现斜线
    这篇文章主要介绍“web中怎么用线性渐变实现斜线”,在日常操作中,相信很多人在web中怎么用线性渐变实现斜线问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”web中怎么用线性渐变实现斜线”的疑惑有所帮助!接下来...
    99+
    2023-06-04
  • Css技术中线性渐变的示例分析
    小编给大家分享一下Css技术中线性渐变的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!对象选择器 {background...
    99+
    2022-10-19
  • 怎么用CSS实现线性渐变的凹面矩形过渡效果
    这篇文章主要介绍“怎么用CSS实现线性渐变的凹面矩形过渡效果”,在日常操作中,相信很多人在怎么用CSS实现线性渐变的凹面矩形过渡效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用CSS实现线性渐变的凹面...
    99+
    2023-06-08
  • css3怎么实现重复的线性渐变
    这篇文章主要介绍“css3怎么实现重复的线性渐变”,在日常操作中,相信很多人在css3怎么实现重复的线性渐变问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css3怎么实现重复...
    99+
    2022-10-19
  • 使用canvas怎么实现一个线性渐变和径向渐变效果
    本篇文章给大家分享的是有关使用canvas怎么实现一个线性渐变和径向渐变效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。fillStyle的第二种使用情况就是渐变色的填充。渐...
    99+
    2023-06-09
  • Css3中的transform渐变属性怎么用
    这篇文章主要介绍了Css3中的transform渐变属性怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。translate()素从其当前...
    99+
    2022-10-19
  • 如何使用css技术的线性渐变来设计彩虹
    这篇文章主要为大家展示了“如何使用css技术的线性渐变来设计彩虹”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用css技术的线性渐变来设计彩虹”这篇文章吧...
    99+
    2022-10-19
  • 在Vue中怎么使用Echarts添加渐变线条
    本篇内容主要讲解“在Vue中怎么使用Echarts添加渐变线条”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“在Vue中怎么使用Echarts添加渐变线条”吧!使用Echarts Gradient...
    99+
    2023-07-06
  • CSS中怎么使用径向渐变实现卡券效果
    这篇文章将为大家详细讲解有关CSS中怎么使用径向渐变实现卡券效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。常见的卡券样式如下: 使用伪元素实现(Less 版本) ticket.less.or...
    99+
    2023-06-08
  • 怎么用CSS制作一个带有渐变边框的圆
    这篇文章主要介绍“怎么用CSS制作一个带有渐变边框的圆”,在日常操作中,相信很多人在怎么用CSS制作一个带有渐变边框的圆问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用C...
    99+
    2022-10-19
  • 怎么利用CSS中linear制作复杂的边框效果
    本篇内容介绍了“怎么利用CSS中linear制作复杂的边框效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2022-10-19
  • css3中怎么使用animation属性实现背景颜色动态渐变的效果
    本篇内容主要讲解“css3中怎么使用animation属性实现背景颜色动态渐变的效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css3中怎么使用animat...
    99+
    2022-10-19
  • css中的flex属性怎么用
    这篇文章主要介绍css中的flex属性怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!   flex   flex 属性用于指定弹性子元素如何分配空间。   语法   f...
    99+
    2022-10-19
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作