background-repeat
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
background-repeat CSS 属性定义背景图像的重复方式。背景图像可以沿着水平轴,垂直轴,两个轴重复,或者根本不重复。
尝试一下
background-repeat: repeat-x; background-repeat: repeat; background-repeat: space; background-repeat: round; background-repeat: no-repeat; background-repeat: space repeat; <section id="default-example"> <div id="example-element"></div> </section> #example-element { background: #ccc url("/shared-assets/images/examples/moon.jpg") center / 120px; min-width: 100%; min-height: 100%; } 默认情况下,重复的图像被剪裁为元素的大小,但它们可以缩放 (使用 round) 或者均匀地分布 (使用 space).
语法
css
/* 单值语法 */ background-repeat: repeat-x; background-repeat: repeat-y; background-repeat: repeat; background-repeat: space; background-repeat: round; background-repeat: no-repeat; /* 双值语法:水平 horizontal | 垂直 vertical */ background-repeat: repeat space; background-repeat: repeat repeat; background-repeat: round space; background-repeat: no-repeat round; background-repeat: inherit; 值
<repeat-style>-
单值语法是完整的双值语法的简写:
单值 等价于双值 repeat-xrepeat no-repeatrepeat-yno-repeat repeatrepeatrepeat repeatspacespace spaceroundround roundno-repeatno-repeat no-repeat在双值语法中,第一个值表示水平重复行为,第二个值表示垂直重复行为。下面是关于每一个值是怎么工作的具体说明:
值 描述 repeat图像会按需重复来覆盖整个背景图片所在的区域。最后一个图像会被裁剪,如果它的大小不合适的话。 space图像会尽可能得重复,但是不会裁剪。第一个和最后一个图像会被固定在元素 (element) 的相应的边上,同时空白会均匀地分布在图像之间。 background-position属性会被忽视,除非只有一个图像能被无裁剪地显示。只在一种情况下裁剪会发生,那就是图像太大了以至于没有足够的空间来完整显示一个图像。round随着允许的空间在尺寸上的增长,被重复的图像将会伸展 (没有空隙), 直到有足够的空间来添加一个图像。当下一个图像被添加后,所有的当前的图像会被压缩来腾出空间。例如,一个图像原始大小是 260px, 重复三次之后,可能会被伸展到 300px, 直到另一个图像被加进来。这样他们就可能被压缩到 225px.译者注:关键是浏览器怎么计算什么时候应该添加一个图像进来,而不是继续伸展。 no-repeat图像不会被重复 (因为背景图像所在的区域将可能没有完全被覆盖). 那个没有被重复的背景图像的位置是由 background-position属性来决定。
标准语法
background-repeat =
<repeat-style>#
<repeat-style> =
repeat-x |
repeat-y |
<repetition>{1,2}
<repetition> =
repeat |
space |
round |
no-repeat
例子
>HTML
html
<ol> <li> no-repeat <div class="one"> </div> </li> <li> repeat <div class="two"> </div> </li> <li> repeat-x <div class="three"> </div> </li> <li> repeat-y <div class="four"> </div> </li> <li> repeat-x, repeat-y (multiple images) <div class="five"> </div> </li> </ol> CSS
css
/* Shared for all DIVS in example */ li { margin-bottom: 12px; } div { background-image: url(star-solid.gif); width: 160px; height: 70px; } /* 因为 space 和 round 当前没有被广泛支持的,所以没有添加*/ .one { background-repeat: no-repeat; } .two { background-repeat: repeat; } .three { background-repeat: repeat-x; } .four { background-repeat: repeat-y; } /* Multiple images */ .five { background-image: url(star-solid.gif), url(/shared-assets/images/examples/favicon32.png); background-repeat: repeat-x, repeat-y; height: 144px; } 结果
在这个例子中,每一个列表项都使用了不同的background-repeat 语法。
规范
| Specification |
|---|
| CSS Backgrounds and Borders Module Level 3> # background-repeat> |
浏览器兼容性
Loading…