线性渐变
径向渐变
新写法
老写法html
最后的老写法镜像渐变可能不太准确。其他都彻底正确web
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>RunJS By 李可</title> <style> .demo { width: 300px; height: 300px; /********************************************整体介绍***********************************************/ /* 新写法:属性“-...-linear-gradient”有三个参数。 第一个参数表示线性渐变的方向,top是从上到下、left是从左到右,若是定义成left top,那就是从左上角到右下角。 第二个和第三个参数分别是起点颜色和终点颜色。你还能够在它们之间插入更多的参数,表示多种颜色的渐变。 webkit老写法:属性“-webkit-gradient”是webkit引擎对渐变的实现,一共有五个参数。 第一个参数表示渐变类型(type),能够是linear(线性渐变)或者radial(辐射渐变)。 第二个参数和第三个参数,都是一对值,分别表示渐变起点和终点。这对值能够用坐标形式表示,也能够用关键值表示,好比left top(左上角)和left bottom(左下角)。 第四个和第五个参数,分别是两个color-stop函数。color-stop函数接受两个参数,第一个表示渐变的位置,0为起点,0.5为中点,1为结束点;第二个表示该点的颜色。 IE依靠滤镜实现渐变。startColorstr表示起点的颜色,endColorstr表示终点颜色。GradientType表示渐变类型,0为缺省值,表示垂直渐变,1表示水平渐变。*/ /********************************************线性渐变***********************************************/ /*w3c新写法推荐*/ /*步步加深*/ /*background-image: linear-gradient(to bottom,red,green);*/ /*background-image: linear-gradient(to bottom,red 0%,green 100%); */ /*按照方向,到25%为一直第一种颜色,25%-75%是渐变,75%-100%也是渐变。*/ /*background-image: linear-gradient(to bottom,red 25%,blue75%,green 100%);*/ /*按照方向,到25%为一直第一种颜色,25%两边的颜色分别用2个值写出来。25%-75%是渐变,75%-100%也是渐变。*/ /*background-image: linear-gradient(to bottom,red 25%,yellow 25%,blue 75%,gray 75%,green 100%);*/ /*加上各个浏览器前缀*/ /*background-image:-webkit-linear-gradient( to bottom,red,green); webkit不支持to*/ /*background-image:-webkit-linear-gradient(top,red,green);*/ /*webkit用这个代替*/ /*background-image:-moz-linear-gradient( to bottom,red,green); */ /*moz支持to*/ /*background-image:-ms-linear-gradient( to bottom,red,green); * /*background-image:-o-linear-gradient( to bottom,red,green);*/ /* moz不支持,但支持-webkit-*/ /*角度:水平为0deg,逆时针转动为正值,顺时针为负值。一周360deg,能够多周转动*/ /*background-image:-moz-linear-gradient(0deg,red,green);*/ /*background-image:-webkit-linear-gradient(270deg,red,green); */ /* background-image:-webkit-linear-gradient(-90deg,red,green); */ /*background-image:-webkit-linear-gradient(450deg,red,green); */ /*新写法实战*/ /*background-image: -webkit-linear-gradient(-45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);*/ /*background-image: -webkit-linear-gradient(-45deg, red 25%, blue 25%,transparent 50%, green 50%, rgba(255, 255, 255, 0.15) 75%, yellow 75%, transparent);*/ /*只有weblit老写法 ,5个参数*/ /* from to只是2个简单的变色*/ /*background-image: -webkit-gradient(linear, 0 0, 0 100%, from(red),to(green));*/ /*color-stop插在 from to的任意位置*/ /*background-image: -webkit-gradient(linear, 0 0, 0 100%,color-stop(50%,#ccc), from(red),color-stop(10%,yellow),to(green),color-stop(80%,blue));*/ /*background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#444444),color-stop(1,#999999));*/ /*老写法实战*/ /*后面能够有to()*/ /*background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(0.25, rgba(222, 255, 255, 0.5)), color-stop(0.25, blue), color-stop(0.5, red), color-stop(0.5, rgba(255, 255, 255, 0.15)), color-stop(0.75, rgba(255, 255, 255, 1)), color-stop(0.75, transparent), to(rgba(255, 255, 255, 1)));*/ /********************************************ie9之前版本使用滤镜***********************************************/ /*GradientType表明渐变线方向,0为垂直(默认),1为水平*/ /*ie8*/ /*-ms-filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='red', endColorstr='#00ff00'); /*ie6,ie7*/ /*filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='red', endColorstr='#00ff00');*/ /******************************bootstrap源码中运用的线性渐变及ie滤镜例子*********************************/ /* background-color: #dd514c; background-image: -moz-linear-gradient(top, #ee5f5b, #c43c35); background-image: -ms-linear-gradient(top, #ee5f5b, #c43c35); background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ee5f5b), to(#c43c35)); background-image: -webkit-linear-gradient(top, #ee5f5b, #c43c35); background-image: -o-linear-gradient(top, #ee5f5b, #c43c35); background-image: linear-gradient(top, #ee5f5b, #c43c35); background-repeat: repeat-x; filter: progid:dximagetransform.microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0);*/ /********************************************重复线性渐变***********************************************/ /*只有当首尾两颜色位置不在0%或100%时,重复渐变才生效*/ /*方向默认从上到下,假如div高度100,第一个20%决定了以20为起点,最后一个50%减去第一个20%等于=30%,100/30=3,div最少分3份,具体分几分,要看起点*/ /*和和线性渐变的主要区别:起点25%,不表示从0到25%是一种颜色,而是补过来的*/ /*background-image: -webkit-repeating-linear-gradient(blue 20%,green 50%); background-image: repeating-linear-gradient(blue 20%,green 50%);*/ /*试一试多个*/ /*background-image: -webkit-repeating-linear-gradient(blue 20%,green 30%,yellow 40%);*/ /********************************************径向渐变***********************************************/ /*新写法*/ /*background-image:-webkit-radial-gradient(red 20%,green);不写坐标,默认在中心*/ /*background-image:-webkit-radial-gradient(150px 150px,red 20%,green);坐标数值*/ /*background-image:-webkit-radial-gradient(left bottom,red 20%,green);*/ /*坐标关键词*/ /*径向渐变的默认cover,手动设定为circle,就不会自动填充*/ /*background-image:-webkit-radial-gradient(150px 150px,circle,red 20%,green 70%,yellow 80%);*/ /*径向渐变同一个位置green 100px,transparent 100px,能够实现截断的目的*/ /*径向渐变red 50px,green 100px,transparent 100px,不按百分比*/ /*background-image:-webkit-radial-gradient(40px 50px,red 50px,green 100px,transparent 100px,transparent);*/ /*transparent能够实现一个div上多个“圆”,多个径向渐变*/ /* background-image:-webkit-radial-gradient(40px 50px,red 50px,green 100px,transparent 100px,transparent), -webkit-radial-gradient(260px 50px,red 50px,green 100px,transparent 100px,transparent), -webkit-radial-gradient(260px 200px,circle,red 50px,green 100px,transparent 100px,transparent);*/ /*多浏览器*/ /* background-image:-webkit-radial-gradient(center center,red 20%,green); background-image:-moz-radial-gradient(center center,red 20%,green); background-image:-ms-radial-gradient(center center,red 20%,green); background-image:-o-radial-gradient(center center,red 20%,green);*/ /*老写法*/ /*规则:-webkit-gradient(type, inner_center, inner_radius, outer_center, outer_radius, / stop...) /* from to只是2个简单的变色*/ /*background-image: -webkit-gradient(radial, 0 0, 50,50 50,60, from(red),to(green));*/ background-image: -webkit-gradient(radial, 1 1, 10, 49 49, 100, color-stop(20%, green), color-stop(20%, red), color-stop(30%, yellow)); /*我的理解:第一个color-stop(20%,green),起点是内圆圆心,重点是外圆的半径长,不固定。 20%是第一个圆心到外半径的任意比例,这个不是固定的长度,由于在各个方向的20%不相等,内圆圆心不在外圆的圆心上,因此不能填写固定值。*/ /*background-image: -webkit-gradient(radial, 30 50, 10,80 80,70,color-stop(0%,green),color-stop(10%,yellow),color-stop(20%,red),color-stop(50%,yellow),color-stop(80%,blue),color-stop(1,transparent));*/ /*内圆圆心跑到外圆包围圈的状况*/ /*background-image: -webkit-gradient(radial, 190 50, 10,80 80,70,color-stop(0%,green),color-stop(10%,yellow),color-stop(20%,red),color-stop(50%,yellow),color-stop(80%,blue),color-stop(1,transparent))*/ /*经常多个环状效果,晕状效果*/ /*background-image: -webkit-gradient(radial, 50 50, 10,80 80,70,color-stop(0%,green),color-stop(10%,yellow),color-stop(20%,red),color-stop(50%,yellow),color-stop(80%,blue),color-stop(1,transparent)),-webkit-gradient(radial, 150 150, 10,180 180,70,color-stop(0%,green),color-stop(10%,yellow),color-stop(20%,red),color-stop(50%,yellow),color-stop(80%,blue),color-stop(1,transparent));*/ } </style> </head> <body> <div class="demo">ddd d</div> </body> </html>