--- title: radial-gradient() slug: Web/CSS/radial-gradient() tags: - CSS - CSS Function - Reference - Web - gradient translation_of: Web/CSS/radial-gradient() ---
{{CSSRef}}
radial-gradient()
CSS函数创建了一个图像,该图像是由从原点发出的两种或者多种颜色之间的逐步过渡组成。它的形状可以是圆形(circle)或椭圆形(ellipse)。这个方法得到的是一个CSS{{cssxref("<gradient>")}}数据类型的对象,其是 {{cssxref("<image>")}} 的一种。
{{EmbedInteractiveExample("pages/css/function-radial-gradient.html")}}
与其它渐变相同,径向渐变是一个不固定尺寸的图像,即,它没有首选的大小,也没有首选的比例。具体大小将由它所应用的元素的大小决定。
如要创建重复的径向渐变来填充容器,请使用CSS的{{ Cssxref("repeating-radial-gradient") }} 方法。
因为 <gradient>
属于 <image>
类型,所以它可以用于任何适用于 <image>
的地方。正是因为这样,radial-gradient()
不能用于 {{Cssxref("background-color")}} 和其他属性比如 {{cssxref("<color>")}} 数据类型。
径向渐变(Radial gradients)由其中心点、边缘形状轮廓、两个或多个色值结束点(color stops)定义而成。
为了创建平滑的渐变,径向渐变函数绘制了一系列从中心点放射到边缘形状(甚至可能超出范围)的同心轮廓。边缘形状可以是圆形(circle)或椭圆形(ellipse)。
色彩结束点位于虚拟渐变射线(Virtual gradient ray)上,该渐变射线从中心点水平向右延伸。 基于百分比的色彩结束位置是相对于边缘形状和此渐变射线之间的交点(代表100%)。 每个形状都是一种单色,并由其相交的渐变射线上的颜色确定。
/* A gradient at the center of its container,
starting red, changing to blue, and finishing green */
radial-gradient(circle at center, red 0, blue, green 100%)
{{cssxref("<position>")}}
<shape>
<size>
<color-stop>
0%
,或者长度值0
,表示渐变中心点;百分比值100%
表示渐变射线与边缘形状相交的点。 其间的百分比值线性对应渐变射线上的点。<extent-keyword>
常量 | 描述 |
---|---|
closest-side |
渐变的边缘形状与容器距离渐变中心点最近的一边相切(圆形)或者至少与距离渐变中心点最近的垂直和水平边相切(椭圆)。 |
closest-corner |
渐变的边缘形状与容器距离渐变中心点最近的一个角相交。 |
farthest-side |
与closest-side相反,边缘形状与容器距离渐变中心点最远的一边相切(或最远的垂直和水平边)。 |
farthest-corner |
渐变的边缘形状与容器距离渐变中心点最远的一个角相交。 |
注意:该函数的早期实现还包含其他关键字( cover
和 contain
),分别相当于标准关键字 farthest-corner
和 closest-side
。但因为在某些实现中丢弃了这些旧的关键字,所以请仅使用标准关键字。
<linear-color-stop>
0%
, or a length of 0
, represents the center of the gradient; the value 100%
represents the intersection of the ending shape with the virtual gradient ray. Percentage values in between are linearly positioned on the gradient ray. Including two stop positions is equivalent to declaring two color stops with the same color at the two positions.<color-hint>
radial-gradient( [ [ circle || <length> ] [ at <position> ]? , | [ ellipse || [ <length> | <percentage> ]{2} ] [ at <position> ]? , | [ [ circle | ellipse ] || <extent-keyword> ] [at <position> ]? , | at <position> , ]? <color-stop-list> [ , <color-stop-list> ]+ ) where <extent-keyword> = closest-corner | closest-side | farthest-corner | farthest-side and <color-stop-list> = [ <linear-color-stop> [, <color-hint>? ]? ]#, <linear-color-stop> and <linear-color-stop> = <color> [ <color-stop-length> ]? and <color-stop-length> = [ <percentage> | <length> ]{1,2} and <color-hint> = [ <percentage> | <length> ]
Note that negative <length>
's are not allowed, however browsers had implemented negative lengths which are now being removed. See the Firefox site compat note.
<div class="radial-gradient"></div>
.radial-gradient { width: 240px; height: 120px; }
.radial-gradient { background-image: radial-gradient(cyan 0%, transparent 20%, salmon 40%); }
{{EmbedLiveSample('Simple_gradient', 120, 120)}}
<div class="radial-gradient"></div>
.radial-gradient { width: 240px; height: 120px; }
.radial-gradient { background-image: radial-gradient(farthest-corner at 40px 40px, #f35 0%, #43e 100%); }
{{EmbedLiveSample('Non-centered_gradient', 240, 120)}}
Note: Please see Using CSS gradients for more examples.
Specification | Status | Comment |
---|---|---|
{{SpecName('CSS3 Images', '#radial-gradients', 'radial-gradients()')}} | {{Spec2('CSS3 Images')}} | Initial definition. |
Gecko used to have a long-standing bug whereby radial gradients like radial-gradient(circle gold,red)
would work, even though they shouldn't because of the missing comma between circle
and gold
. Also, {{cssxref("calc")}} expressions were rejected — causing the value to be invalid — when used as the radius component of a radial-gradient()
function ({{bug(1376019)}}). Firefox's new parallel CSS engine (also known as Quantum CSS or Stylo, released in Firefox 57) fixed these bugs.