CSS3背景渐变效果

学习要点:
1.线性渐变
2.径向渐变

本章主要探讨HTML5中CSS3背景渐变功能,主要有两种渐变方式:线性渐变和径向 (放射性)渐变。

一.线性渐变

linear-gradient背景颜色的渐变功能
CSS3提供了linear-gradient属性实现背景颜色的渐变功能。在以前,这种效果必须采用图片才能实现的。首先,我们先看一下它的样式表,如下:             

linear-gradient(方位,起始色,末尾色)

                      方位          可选参数,渐变的方位。可以使用的值有:

                            totop、to topright、to right、to bottom、to bottomleft、toleft、to top left。

 

                  起始色         必选参数,颜色值

 

                  末尾色         必选参数,颜色值

两个必须参数

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image: linear-gradient(#ffbe18, #138010);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

增加一个方位

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image: linear-gradient( to top,#ffbe18, #138010);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

通过top、left、right、bottom这四组实现的渐变方向有时比较单一,我们可以使用以角度单位的数值来设置方位。比如 度(0deg)相当于totop;角度会沿逆时针方向随着你的角度的增加而增加。

通过角度设置方位, ~ 36 度之间,可以是负值

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image: linear-gradient(45deg, #ffa500, #008000);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

多色线性渐变

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image: linear-gradient(-45deg, #ffa500, #008000, #0000ff, #ff0000);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

通过百分比设置多色线性位置

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image:linear-gradient(-45deg, #ffa500 0%, #008000 20%, #0000ff 40%, #ff0000 1%);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

默认情况下:起始颜色的百分比位置是0%,末尾颜色的百分比位置是1 %,其他位置按照平均值分配。也可以使用px像素来设定,但计算麻烦点。 

结合背景,并使用透明渐变实现强大层次感

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-color: red;
  5. background-image: linear-gradient(to top right, rgba(0,0,0,0.6),rgba(0,0,0,0));
  6. }
  7.  
  8. <p>是一部由北青传媒股份</p>

重复渐变属性值

  1. p{
  2. width: 200px;
  3. height: 100px;
  4. background-image:repeating-linear-gradient(to top,orange 10px, green 30px);
  5. }
  6.  
  7. <p>是一部由北青传媒股份</p>

 目前最新的主流浏览器都支持CSS3的渐变属性,那么对于之前的浏览器支持度如何呢?可以参考如下的表:

                                Opera        Firefox      Chrome         Safari          IE

     部分支持需带前缀        11.5                  无             4 ~ 9            4 ~ 5            无

       支持需带前缀                   无             3.6 ~ 15        1 ~ 25       5.1~ 6             无

       支持不带前缀                   12.1+               16+                  26+                    6.1+                 10.0+

这里提到了部分支持,说明当时可能渐变还尚未完善,但可以通过添加前缀来使用它了。具体哪些没完善,已经无法考证了,版本太过久远。那么支持带前缀和不支持带前缀的完整 格式如下:

加上兼容前缀

  1. p{
  2. background-image: -webkit-linear-gradient(to top, orange, green);
  3. background-image: -moz-linear-gradient(to top, orange, green);
  4. background-image: -o-linear-gradient(to top, orange, green);
  5. background-image: linear-gradient(to top, orange, green);
  6. }
  7.  
  8. <p>是一部由北青传媒股份</p>

repeating-linear-gradient属性值和linear-gradient基本相同,不在赘述。 

二.径向渐变

radial-gradient背景径向渐变
CSS3提供了径向渐变,也叫做放射性渐变:radial-gradient属性值。它是从一个点向四周发散的方式扩展。属性值样式表如下:

radial-gradient(方位,起始色,末尾色)

             方位                  可选参数,径向的方位。可以使用的值有:像素、百分比、固定值,或复合搭配使用                    

           起始色                 必选参数,颜色值

           末尾色                 必选参数,颜色值

两个必选参数

  1. p{
  2. background-image: radial-gradient(orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

如果想设置第一个可选参数,有一种做法是设置为:cirlce(圆形)或ellipse(椭圆形)。默认是椭圆形。

           形状                   说明

           circle             圆形

          ellipse            椭圆形,默认值

  1. p{
  2. background-image: radial-gradient(circle, orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

不单单可以设置形状,还可以设置形状的发散方向 

            方向                       说明

            top                  从顶部发散

            left                    从左侧发散

           right              从右侧发散

           bottom              从底部发散

           center             从中间发散

  1. p{
  2. background-image: radial-gradient(circle at top, orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

也可以复合方向,比如右下方

  1. p{
  2. background-image: radial-gradient(circle at right bottom, orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

可以设置发散的距离,即圆的半径长度 

         半径关键字                     说明

       closest-side          指定径向渐变的半径长度为从圆心到离圆心最近的边

      closest-corner       指定径向渐变的半径长度为从圆心到离圆心最近的角

       farthest-side        指定径向渐变的半径长度为从圆心到离圆心最远的边

      farthest-corner     指定径向渐变的半径长度为从圆心到离圆心最远的角

  1. p{
  2. background-image:radial-gradient(circle closest-side,orange,green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

关键字有点拗口,可以用像素表示半径,但不接受百分比

  1. p{
  2. background-image: radial-gradient(circle 50px, orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

同样,也有重复背景方式

  1. p{
  2. background-image: repeating-radial-gradient(circle 50px, orange, green);
  3. }
  4.  
  5. <p>是一部由北青传媒股份</p>

兼容模式 

  1. p{
  2. background-image: -webkit-radial-gradient(circle,orange, green);
  3. background-image: -moz-radial-gradient(circle,orange, green);
  4. background-image: -o-radial-gradient(circle,orange, green);
  5. background-image: radial-gradient(circle, orange, green);
  6. }
  7.  
  8. <p>是一部由北青传媒股份</p>

两个重复背景只要加上前缀就是兼容模式了 

  1. background-image: -webkit-repeating-radial-gradient
    background-image: -moz-repeating-radial-gradient
    background-image: -o-repeating-radial-gradient
    background-image: repeating-radial-gradient

第七十九,CSS3背景渐变效果的更多相关文章

  1. 第三百七十九节,Django+Xadmin打造上线标准的在线教育平台—xadmin的安装

    第三百七十九节,Django+Xadmin打造上线标准的在线教育平台—xadmin的安装 xadmin介绍 xadmin是基于Django的admin开发的更完善的后台管理系统,页面基于Bootstr ...

  2. “全栈2019”Java第七十九章:类中可以嵌套接口吗?

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  3. (七十九)c#Winform自定义控件-导航菜单

    前提 入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章. GitHub:https://github.com/kwwwvagaa/NetWinformControl 码云:ht ...

  4. 第一百七十九节,jQuery-UI,知问前端--按钮 UI-图标

    jQuery-UI,知问前端--按钮 UI 学习要点: 1.使用 button 按钮 2.修改 button 样式 3.button()方法的属性 4.button('action', param) ...

  5. salesforce零基础学习(七十九)简单排序浅谈 篇一

    我们在程序中经常需要对数据列表进行排序,有时候使用SOQL的order by 不一定能完全符合需求,需要对数据进行排序,排序可以有多种方式,不同的方式针对不同的场景.篇一只是简单的描述一下选择排序,插 ...

  6. (七十九)MapKit的基本使用

    MapKit是苹果公司开发的用于显示地图和实现定位.导航的地图框架. MapKit View可以通过storyboard.xib创建,也可以通过代码直接创建. 需要注意的是,通过storyboard和 ...

  7. Java开发笔记(七十九)利用反射技术操作私有属性

    早在介绍多态的时候,曾经提到公鸡实例的性别属性可能被篡改为雌性,不过面向对象的三大特性包含了封装.继承和多态,只要把性别属性设置为private私有级别,也不提供setSex这样的性别修改方法,那么性 ...

  8. 第七十九课 最短路径(Floyd)

    程序如下: #ifndef GRAPH_H #define GRAPH_H #include "Object.h" #include "SharedPointer.h&q ...

  9. C#编程(七十九)---------- 反射

    反射 在介绍翻着之前,先说两个小案例 B超:什么叫B超呢?就是透过肚皮能看到你内脏的情况,不用打开肚子才能看.这是什么样的一种技术呢?B超是B型超声波,它可以透过肚皮通过向你体内发射B型超声波,当超声 ...

随机推荐

  1. 实际开发中,后台回传的错误格式的Json数据处理

    现在很多学习刚学习移动开发的同学,相信在培训机构,拿到后台数据的时候,格式都是正确的,甚至有的还是plist文件.但是实际开发中,我们获取数据都是通过网络接口从服务器获取数据,这些数据的格式都是后台写 ...

  2. php_Symfony_项目实战全过程记录

    今天是2017年1月8号,正式接收到一个Symfony 的项目,准备全程记录遇到的问题及解决方法,之前被通知学习该框架,只是一直没有机会做项目,今天终于可以做了,希望2017把Symfony学的能会使 ...

  3. ProgrammingContestChallengeBook

    POJ 1852 Ants POJ 2386 Lake Counting POJ 1979 Red and Black AOJ 0118 Property Distribution AOJ 0333 ...

  4. XtraBackup增量备份

    mysql:5.6.29xtrabackup:2.2.10mysql数据目录:/data/mysqlmysql备份目录:/data/dbbak/ #确保有足够的磁盘空间 官方文档:https://ww ...

  5. Linux 下安裝 Java SE Development Kit(JDK)並配置環境變量

    下載頁面:http://www.oracle.com/technetwork/java/javase/archive-139210.html 打開“Java SE 7”,再打開“Java SE Dev ...

  6. Discuz! X3.2重置管理员账号

    主要是使用了Tools急诊箱.先看一下Tools急诊箱的主要功能: 多种模式在线安装Discuz!,或者重装 重置管理员账号:将把您指定的会员设置为管理员 关闭功能:一键关闭/打开 [站点|插件]的操 ...

  7. c++中string类型可以直接进行比较

    以下代码在Ubuntu14.10下实现 /*------------------------- filename is demo.cpp --------------------------*/ #i ...

  8. 【IE6的疯狂之十一】CSS的优先级及!important在IE6下的BUG

    一 css的优先级 今天有人跟我说css hack中用!important来区分ie6,因为ie6不支持!important,是的在很早以前我也是用过这种方法写hack,但是后来就基本不用了.本来我对 ...

  9. php学习笔记——基础知识(1)

    1.PHP 脚本在服务器上执行,然后向浏览器发送回纯 HTML 结果. 2.基础 PHP 语法 1)PHP 脚本可放置于文档中的任何位置. 2)PHP 脚本以 <?php 开头,以 ?> ...

  10. WPF 限制Textbox输入的内容

    限制文本框TextBox的输入内容,在很多场景都有应用.举个例子,现在文本框中,只能输入0.1.2.3.4.5.6.7.8.9.“|”这11个字符. 限制输入0-9很容易实现,关键是这个“|”符号.它 ...