css使用线性渐变属性没有用是怎么回事

html-css016

css使用线性渐变属性没有用是怎么回事,第1张

首先,blue和red之间要加个逗号,即

background:-moz-linear-gradient(top,blue,red)

其次,由于用了moz前缀,所以只有运行于火狐浏览器才有效。

如果想运行于webkit内核的浏览器(比如Chrome、Safari),则改为

background:-webkit-linear-gradient(top,blue,red)

至于IE(指低版本的),由于不支持css3,就只能用它本身的滤镜了。

css3目前还不完善,transition目前不支持渐变的背景属性(它被看作是图片了,图片是不能transition的,这个知道吧),so U can't transition gradients for now.

但是呢,你可以做一个掩眼法,前端嘛,css给了你无限发挥的空间。

css:

<style>

body{

margin: 0

padding: 0

}

.gavin_design div{

width: 200px

height: 200px

margin: 20px auto

}

.no{

background: #ccc

-webkit-transition: all 2s linear

}

.no:hover{

background: #f60

}

.line{

position: relative

background: -webkit-linear-gradient(top,#f60,#47CC38)

}

.line_gavinfix{

position: absolute

    top: 0

    left: 0

    width: 100%

    height: 100%

    opacity: 0

    background: -webkit-linear-gradient(top,#47CC38,#f60)

-webkit-transition: opacity 2s linear

}

.line:hover .line_gavinfix{

opacity: 1

}

</style>

html:

<div class="gavin_design">

 <div class="no"></div>

 <div class="line"><span class="line_gavinfix"></span></div>

</div>

预览一下,怎么样?是你需要的么^.^

CSS提供了一种绘制渐变图的机制,这个渐变的机制可以接受任何图片的属性联合使用,包括background-image,我们可以尝试使用一个渐变背景:

有些旧版本的WebKit浏览器只支持线性渐变

使用到的linear-gradient()函数,可以假设一条线,从元素顶部到底部绘制了一个渐变背景,这条线的角度由这个函数的前面关键字(to,bottom),位置由0%处的颜色是浅灰色,而位置100%处也就是元素顶部的颜色是深蓝色。

渐变线的方向可以使用关键字to,再加上一个表示边的(top、right、bottom、left)或者使用角来表示(top left、top right、bottom left、bottom right)的关键字来指定。

此外还可以使用deg单位指定渐变线的角度,0deg表示垂直向上,增大角度值就意味着沿顺时针方向旋转,直到360deg,度数表示绘制渐变的方向,因此起点就在我们指定的相反方向。

当设置为45deg的渐变:

线性渐变的默认方向是自上而下的,而且0%和100%分别表示第一个和最后一个色标的位置,因此,可以简写为:

新增色标若未指定位置,则在0%~100%范围内取均值,比如:有3个未指定位置的色标,那么它们的位置分布为0%、50%、100%

除了百分比外,还可以使用绝对值指定色标的位置,比如:

这种写法渐变是顶部从浅蓝色开始渐变,往下走100px之后过渡到深蓝色,然后一直到底部都是深蓝色。