В CSS 2.1 свойство background-repeat имеет четыре значения: no-repeat, repeat, repeat-x и repeat-y. Хотя они, безусловно, полезны, но не позволяют полностью управлять процессом повторения и картинки будут обрезаны, если они не помещаются в контейнер точное число раз.
CSS3 вводит два новых варианта: space и round.
Вариант space будет повторять картинки по горизонтали и вертикали без обрезания или изменения размера изображения:
background-repeat: space;
Вариант round будет повторять картинки по горизонтали и вертикали без обрезания, но изображение может быть изменено:
background-repeat: round;
Предположим, у нас есть фоновое изображение шириной 100px (фактический размер или изменённый с помощью свойства background-size). Оно располагается в элементе шириной 520px по горизонтали, тогда:
round(520 / 100) = round(5.2) = 5
Браузер будет показывать пять изображений, но задаст ширину картинка как 104px (520px/5). Изображение сделано шире, чтобы вписываться в контейнер.
background-repeat может содержать два значения для изменения горизонтального и вертикального повторения:
background-repeat: round space; /* ширина меняется, высота нет */ background-repeat: space round; /* ширина исходная, высота меняется */ background-repeat: space no-repeat; /* повторять только по горизонтали */
Повторения через space или round будут работать, как вы предполагаете, только когда background-position задано как 0 0. Вы можете свободно менять его, размеры изображений и расстояние между ними останутся теми же, но соответственно сместится левый верхний угол.
Два браузера поддерживают свойства с round и space. Угадайте, какие? Ошибаетесь: это IE9 и Opera. На момент написания статьи, эти значения не реализованы в Firefox, Chrome или Safari. Но всё хуже.
Здорово. Спасибо, ребята.
Единственный способ добиться какого-то единства, это заставить Firefox отображать как Webkit.
#element { background-repeat: no-repeat; background-repeat: space; }
Итак.
Неприятно. Будет лучше подождать несколько месяцев, пока Mozilla и Webkit включит полную поддержку background-repeat.
Сайт