1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
|
---
title: repeat()
slug: Web/CSS/repeat()
tags:
- CSS
- CSS Grid
- Función CSS
- Layout
- Maquetado
- Referencia
- Web
translation_of: Web/CSS/repeat()
---
<div>{{cssref}}</div>
<p><span class="seoSummary">La función <a href="/en-US/docs/Web/CSS">CSS</a> </span><span class="seoSummary"><span class="seoSummary"><code><strong>repeat()</strong></code></span> representa un fragmento repetido de la lista de la pista, permitiendo un gran número de columnas o renglones que exhiben un patrón recurrente para ser escrito de una forma más compacta.</span></p>
<p>Esta función puede ser usada en las propiedades CSS Grid {{cssxref("grid-template-columns")}} y {{cssxref("grid-template-rows")}}.</p>
<pre class="brush: css no-line-numbers notranslate">/* <track-repeat> values */
repeat(4, 1fr)
repeat(4, [col-start] 250px [col-end])
repeat(4, [col-start] 60% [col-end])
repeat(4, [col-start] 1fr [col-end])
repeat(4, [col-start] min-content [col-end])
repeat(4, [col-start] max-content [col-end])
repeat(4, [col-start] auto [col-end])
repeat(4, [col-start] minmax(100px, 1fr) [col-end])
repeat(4, [col-start] fit-content(200px) [col-end])
repeat(4, 10px [col-start] 30% [col-middle] auto [col-end])
repeat(4, [col-start] min-content [col-middle] max-content [col-end])
/* <auto-repeat> values */
repeat(auto-fill, 250px)
repeat(auto-fit, 250px)
repeat(auto-fill, [col-start] 250px [col-end])
repeat(auto-fit, [col-start] 250px [col-end])
repeat(auto-fill, [col-start] minmax(100px, 1fr) [col-end])
repeat(auto-fill, 10px [col-start] 30% [col-middle] 400px [col-end])
/* <fixed-repeat> values */
repeat(4, 250px)
repeat(4, [col-start] 250px [col-end])
repeat(4, [col-start] 60% [col-end])
repeat(4, [col-start] minmax(100px, 1fr) [col-end])
repeat(4, [col-start] fit-content(200px) [col-end])
repeat(4, 10px [col-start] 30% [col-middle] 400px [col-end])
</pre>
<h2 id="Síntaxis">Síntaxis</h2>
<h3 id="Valores">Valores</h3>
<dl>
<dt>{{cssxref("<length>")}}</dt>
<dd>Una longitud no negativa.</dd>
<dt>{{cssxref("<percentage>")}}</dt>
<dd>Un porcentaje no negativo relativo con el tamaño en línea del contenedor de la cuadrícula en las pistas de la cuadrícula de columna, y el tamaño del bloque del contenedor de la cuadrícula en las pistas de la cuadrúcula de la fila. Si el tamaño de la rejilla depende del tamaño de sus pistas, entonces el <code><percentage></code> debe ser tratado como <code>auto</code>. El agente de usuario puede ajustar las contribuciones de tamaño intrínseco de la pista al tamaño del contenedor de la rejilla y aumentar el tamaño final de la pista en la cantidad que resultaría en respetar el porcentaje.</dd>
<dt>{{cssxref("<flex>")}}</dt>
<dd>Una dimensión no negativa con la unidad <code>fr</code> especificando el factor flexible de la pista. Cada pista de tamaño <code><flex></code> comparte el espacio restante en proporción a su factor flex</dd>
<dt><code>max-content </code></dt>
<dd>Representa la contribución mas grande de max-content de los elementos de la cuadrícula ocupando la pista.</dd>
<dt><code>min-content</code></dt>
<dd>Representa la contribución más pequeña min-content de los elementos de la cuadrícula ocupando la pista.</dd>
<dt><code>auto</code></dt>
<dd>Como un máximo, idéntico a <code>max-content</code>. Como un mínimo representa el mayor tamaño mínimo (como se específica en {{cssxref("min-width")}}/{{cssxref("min-height")}}) de los elementos de la cuadrícula ocupando la pista.</dd>
<dt><code>auto-fill</code></dt>
<dd>Si el contenedor de cuadrícula tiene un tamaño definido o máximo en el eje relevante, entonces el número de repeticiones es el mayor entero positivo posible que no hace que la cuadrícula desborde su contenedor de cuadrícula. Tratando cada pista con su función de dimensiones máximo de pista (cada valor se utiliza individualmente para definir <code>grid-template-rows</code> o <code>grid-template-columns</code>), si está definido. De lo contrario, como su función de tamaño mínimo de pista, y teniendo en cuenta la brecha de cuadrícula. Si se desbordara cualquier número de repeticiones, entonces la repetición es <code>1</code>. De lo contrario, si el contenedor de la cuadrícula tiene un tamaño mínimo definido en el eje relevante, el número de repeticiones es el número entero positivo más pequeño posible que cumple ese requisito mínimo. De lo contrario, la lista de pistas especificada se repite solo una vez.</dd>
<dt><code>auto-fit</code></dt>
<dd>
<p>Se comporta igual que el autocompletado <code>auto-fill</code>, excepto que después de colocar los elementos de la cuadrícula se colapsan las pistas vacías repetidas. Una pista vacía es aquella sin elementos de cuadrícula colocados o que se extienden a través de ella. (Esto puede provocar el colapso de todas las pistas, si están todas vacías).</p>
<p dir="ltr">Una pista colapsada se trata como si tuviera una única función de tamaño de pista fija de <code>0px</code>, y los canales (gutters) a cada lado de ella colapsan.</p>
<p dir="ltr">Con el fin de encontrar el número de pistas repetidas automáticamente, el agente de usuario distribuye el tamaño de la pista a un valor especificado por el agente de usuario (por ejemplo, <code>1px)</code>, para evitar la división por cero.</p>
</dd>
</dl>
<h2 id="Ejemplo">Ejemplo</h2>
<h3 id="CSS">CSS</h3>
<pre class="brush: css; highlight[3] notranslate">#container {
display: grid;
grid-template-columns: repeat(2, 50px 1fr) 100px;
grid-gap: 5px;
box-sizing: border-box;
height: 200px;
width: 100%;
background-color: #8cffa0;
padding: 10px;
}
#container > div {
background-color: #8ca0ff;
padding: 5px;
}
</pre>
<h3 id="HTML">HTML</h3>
<pre class="brush: html notranslate"><div id="container">
<div>
Este elemento tiene un ancho de 50 pixels.
</div>
<div>
Elemento con un ancho flexible.
</div>
<div>
Este elemento tiene un ancho de 50 pixels.
</div>
<div>
Elemento con un ancho flexible.
</div>
<div>
Este elemento tiene un ancho de 100 pixels.
</div>
</div></pre>
<h3 id="Resultados">Resultados</h3>
<p>{{EmbedLiveSample("Example", "100%", 200)}}</p>
<h2 id="Especificaciones">Especificaciones</h2>
<table class="standard-table">
<thead>
<tr>
<th>Specification</th>
<th>Status</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>{{SpecName("CSS Grid", "#funcdef-repeat", "repeat()")}}</td>
<td>{{Spec2("CSS Grid")}}</td>
<td>Initial definition</td>
</tr>
</tbody>
</table>
<h2 id="Compatibilidad_del_navegador">Compatibilidad del navegador</h2>
<p>{{Compat("css.properties.grid-template-columns.repeat")}}</p>
|