CSS渐变之CSS3 gradient在Firefox3.6下的使用

原文地址: http://hacks.mozilla.org/2009/11/css-gradients-firefox-36/
原文做者: Alix Franquet

翻译做者:张鑫旭php

1、引子

Firefox3.6包含了许多CSS的改进,本文将向您展现若是使用CSS渐变。css

若是你正在运行的Firefox 3.6的最新测试版,你应该看看咱们的互 动演示,并查看相应的代码。使用单选按钮来切换不一样的样式选项。
demo页面样式切换示意 张鑫旭-鑫空间-鑫生活css3

2、含CSS渐变的背景(backgrounds)

背景使用CSS渐变显示能够不使用图像就实现两个或两个以上的指定颜色的平滑过渡。这反过来又减小了下载时间和带宽的使用,放大时也比较好看,能够 让您创造出一个更灵活的布局。web

Firefox支持两种类型的CSS渐变:线性的(-moz-linear-gradient) 和放射状的(-moz-radial-gradient)。ide

3、线性渐变(Linear Gradients)

要建立一个线性渐变, 您须要设置一个起点和一个渐变的方向(或角度),并定义起止颜色。布局

-moz-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )

起始点(Starting Point):起点的工做方式相似于background position。您能够设置水平和垂直位置为百分比,或以像素为单位,或在水平方向上可使用left/center/right,在垂直方 向上可使用top/center/bottom。位置起始于左上角。若是你不指定水平或垂直位置,它将默认为center。测试

例如,这里是一个线性渐变,开始于center(水平发现)和top(垂直发现),并从蓝色到白色。url

Firefox CSS渐变 basic_linear_bluetop 张鑫旭-鑫空间-鑫生活

代码以下:spa

.linear_gradient_square {   width: 100px;   height: 100px;   border: 1px solid #333;   background: -moz-linear-gradient(top, blue, white); }

或者是起始于left(水平方向)和center(垂直方向).net

Firefox下的CSS蓝白线性渐变 张鑫旭-鑫空间-鑫生活

主要部分代码以下:

background: -moz-linear-gradient(left, blue, white);

或者是起始于left(水平方向)和top(垂直方向)

Firefox下的CSS蓝白线性渐变 张鑫旭-鑫空间-鑫生活

主要部分代码以下:

background: -moz-linear-gradient(left top, blue, white);

角度(Angle):正如您在上面看到的,若是您不指定一个角度,它会根据起始位置自动定义。若是你想更多的控 制渐变的方向,您不妨设置角度试试。

例如,下面的两个渐变具备相同的起点left center,可是右手边的有一个20度的角度。

Firefox下的CSS线性渐变角度 张鑫旭-鑫空间-鑫生活

后面一个含有角度的渐变核心代码以下:

background: -moz-linear-gradient(left 20deg, black, white);

当指定的角度,请记住,它是一个由水平线与渐变线产生的的角度,逆时针方向。所以,使用0deg将产生一个左到右横向梯度,而90度将建立一个从底 部到顶部的垂直渐变。

Firefox下的CSS线性渐变角度 张鑫旭-鑫空间-鑫生活

核心代码以下:

background: -moz-linear-gradient(<angle>, red, white);

起止颜色(Color Stops):除了起始位置和角度,你应该指定起止颜色。起止颜色是沿着渐变线,将会在 指定位置(以百分比或长度设定)含有指定颜色的点。色彩的起止数是无限的。若是您使用一个百分比位置,0%表明起点和100%是终点,但区域外的值能够被 用来达到预期的效果。

下面是一个简单的例子,三个起止颜色。由于第一个和最后的颜色并未指定颜色点,他们将显示为默认的0%和100%。

Firefox下的CSS线性渐变之起止颜色 张鑫旭-鑫空间-鑫生活
background: -moz-linear-gradient(top, blue, white 80%, orange);

若是没有指定位置,颜色会均匀分布。

Firefox下的CSS线性渐变之彩虹色 张鑫旭-鑫空间-鑫生活

核心代码以下:

background: -moz-linear-gradient(left, red, orange, yellow, green, blue);

透明度(Transparency):还支持透明渐变。这是至关有用的,例如,当堆叠多个背景时。这里是两个背 景的结合:一张图片,一个白色到透明的线性渐变。

Firefox下的CSS线性渐变之透明度混合背景 张鑫旭-鑫空间-鑫生活
Firefox下的CSS线性渐变之透明度混合背景 张鑫旭-鑫空间-鑫生活

核心代码以下:

.multibackground_transparent {     background: -moz-linear-gradient(right, rgba(255,255,255,), rgba(255,255,255,1)), url(http://demos.hacks.mozilla.org/openweb/resources/images/patterns/flowers-pattern.jpg); }

4、径向渐变(Radial Gradients)

为径向渐变的语法很是相似于线性渐变。

-moz-radial-gradient([<bg-position> || <angle>,]? [<shape> || <size>,]? <color-stop>, <color-stop>[, <color-stop>]*);

除了您已经在线性渐变中看到的起始位置,方向,和颜色,径向梯度容许你指定渐变的形状(圆形或椭圆形)和大小(最近端,最近角,最远端,最远角,包 含或覆盖 (closest-side, closest-corner, farthest-side, farthest-corner, contain or cover))。

颜色起止(Color stops):就像用线性渐变,你应该沿着渐变线定义渐变的起止颜色。下面的圆具备相同 的起止颜色,但在左边的为默认的颜色间隔均匀的渐变,而右边的每种颜色都有特定的位置。

Firefox下的CSS径向渐变之起止颜色 张鑫旭-鑫空间-鑫生活
background: -moz-radial-gradient(red, yellow, #1E90FF);  background: -moz-radial-gradient(red 5%, yellow 25%, #1E90FF 50%);

形状(Shape):在这里你能够看到两个可能的形状间的差别,一个圆(左侧)和椭圆(右侧),二者都起始于 bottom left:

Firefox下的CSS径向渐变之形状 张鑫旭-鑫空间-鑫生活
.radial_gradient_circle {     background: -moz-radial-gradient(bottom left, circle, red, yellow, #1E90FF); }  .radial_gradient_ellipse {     background: -moz-radial-gradient(bottom left, ellipse, red, yellow, #1E90FF); }

大小(Size):size的不一样选项(closest-side, closest-corner, farthest-side, farthest-corner, contain or cover)指向被用来定义圆或椭圆大小的点。

示例:椭圆的近边VS远角
下面的两个椭圆有不一样的大小。左边的一个是由从起始点(center)到近边的距离设定的,而右边的一个是由从起 始点到远角的的距离决定的。

Firefox下的CSS径向渐变之大小 张鑫旭-鑫空间-鑫生活
background: -moz-radial-gradient(ellipse closest-side, red, yellow 10%, #1E90FF 50%, white);   background: -moz-radial-gradient(ellipse farthest-corner, red, yellow 10%, #1E90FF 50%, white);
近边与远角的示意 张鑫旭-鑫空间-鑫生活

示例:圆的近边VS远边
左边的圆的渐变大小由起始点(center)到近边的距离决定,而右边的圆则有起始点到远边的距离决定。

Firefox下的CSS径向渐变之大小 张鑫旭-鑫空间-鑫生活
background: -moz-radial-gradient(circle closest-side, red, yellow 10%, #1E90FF 50%, white);  background: -moz-radial-gradient(circle farthest-side, red, yellow 10%, #1E90FF 50%, white);

示例:包含圆
在这里你能够看到左侧的默认圈,同一渐变版本,可是被包含的右边的圆。

Firefox下的CSS径向渐变之大小包含 张鑫旭-鑫空间-鑫生活
background: -moz-radial-gradient(red, yellow, #1E90FF);  background: -moz-radial-gradient(contain, red, yellow, #1E90FF);

5、重复渐变(Repeating Gradients)

若是您想重复一个渐变,您可使用-moz-repeating-linear-gradient-moz-repeating-radial-gradient

在下面的例子,每一个实例都指定了四个起止颜色,并没有限重复。

Firefox下的CSS重复渐变 张鑫旭-鑫空间-鑫生活
.repeating_radial_gradient_example {     background: -moz-repeating-radial-gradient(black, black 5px, white 5px, white 10px); }  .repeating_linear_gradient_example {      background: -moz-repeating-linear-gradient(top left -45deg, red, red 5px, white 5px, white 10px); }

Demo
您能够查看线 性和径向渐变demo获取更多示例

6、译者的结语

以上为全文的所有内容,除了最后一点点关于版本的问题没有翻译外,其他均尽可能如实翻译,其中为了便于理解,我本身也添加了一些图片。最后,本人翻译 能力有限,出现不许确在所不免,欢迎指正。

若是您发现文章中有表述不许确或是有相关问题须要交流能够经过评论或是去 这里进行提问交流。
相关文章
相关标签/搜索