--- title: grid-template-columns slug: Web/CSS/grid-template-columns tags: - CSS Grid - CSS сетка - grid translation_of: Web/CSS/grid-template-columns --- <p><span class="seoSummary">CSS свойство <strong><code>grid-template-columns</code></strong> определяет имена линий и функции гибкости линий. {{glossary("grid column", "grid columns")}}. Другими словами, задаёт количество столбцов "колонок" в сетке и может определять ширину каждой из них.</span></p> <p>{{EmbedInteractiveExample("pages/css/grid-template-columns.html")}}</p> <h2 id="Синтаксис">Синтаксис</h2> <pre class="brush: css notranslate">/* Keyword value */ grid-template-columns: none; /* <track-list> values */ grid-template-columns: 100px 1fr; grid-template-columns: [linename] 100px; grid-template-columns: [linename1] 100px [linename2 linename3]; grid-template-columns: minmax(100px, 1fr); grid-template-columns: fit-content(40%); grid-template-columns: repeat(3, 200px); /* <auto-track-list> values */ grid-template-columns: 200px repeat(auto-fill, 100px) 300px; grid-template-columns: minmax(100px, max-content) repeat(auto-fill, 200px) 20%; grid-template-columns: [linename1] 100px [linename2] repeat(auto-fit, [linename3 linename4] 300px) 100px; grid-template-columns: [linename1 linename2] 100px repeat(auto-fit, [linename1] 300px) [linename3]; /* Global values */ grid-template-columns: inherit; grid-template-columns: initial; grid-template-columns: unset; </pre> <h3 id="Значения">Значения</h3> <dl> <dt><code>none</code></dt> <dd>Это ключевое слово означает, что нет никакой явной сетки. Любые столбцы будут создаваться неявно, и их размер будет определяться свойством {{cssxref("grid-auto-columns")}} .</dd> <dt>{{cssxref("<length>")}}</dt> <dd>Не-отрицательная длина.</dd> <dt>{{cssxref("<percentage>")}}</dt> <dd>Не-отрицательное {{cssxref("percentage", "<percentage>")}} значение относительно встроенного контейнера сетки. Если размер сетки контейнера зависим от размера ряда элементов, то процент будет установлен автоматически.<br> Ручное изменение размера элемента в процентах, приведёт к корректировочному изменению размера контейнера, и увеличит размер ряда на минимальную величину, необходимую для соблюдения процентного соотношения. </dd> <dt>{{cssxref("<flex>")}}</dt> <dd>Не-отрицательное значение с единицей измерения <code>fr</code>, которая строго определяет <em>flex фактор линий</em> (track’s flex factor, <em>фактор гибкости линий</em>). Каждая <code><flex></code>-размерная линия берёт оставшееся пространство пропорционально flex фактору. <p>Когда из вне появляется <code>minmax()</code> , это предполагает автоматический минимум (т.е. <code>minmax(auto, <flex>)</code>).</p> </dd> <dt id="max-content"><code>max-content</code></dt> <dd>Ключевое слово обозначающее самый большой из максимальных контентов элементов расположенных в данном треке.</dd> <dt><code>min-content</code></dt> <dd>Ключевое слово обозначающее самый большой из минимальных контентов элементов расположенных в данном треке.</dd> <dt><code>{{cssxref("minmax", "minmax(min, max)")}}</code></dt> <dd>Функциональное обозначение, которое задаёт диапазон больший или равный <em>min</em> и меньший или равный <em>max</em>. Если <em>max</em> меньше чем <em>min</em>, тогда <em>max</em> игнорируется и эта функция рассматривается как <em>min</em>. Максимумом значение <code><flex></code> устанавливает flex фактор линии (track’s flex factor). Оно не действительно как минимальное.</dd> <dt id="auto"><code>auto</code></dt> <dd>Это ключевое слово идентично <code>max-content</code>, если оно максимальное. Как минимальное, оно представляет наиболее минимальный размер (который определён в свойствах {{cssxref("min-width")}}/{{cssxref("min-height")}}) элементов сетки, занимающих данный трек.</dd> <dd> <p class="note">Обратите внимание: Только <code>auto</code> размеры трека могут быть растянуты свойствами {{cssxref("align-content")}} и {{cssxref("justify-content")}}.</p> </dd> <dt id="fit-content()"><code>{{cssxref("fit-content", "fit-content( [ <length> | <percentage> ] )")}}</code></dt> <dd>Представляет формулу <code>min(max-content, max(auto, <var>argument</var>))</code>, которая вычисляется подобно <code>auto</code> (т.е. <code>minmax(auto, max-content)</code>), за исключением того, что размер трека ограничивается <var>argument, если он больше минимума по</var> <code>auto</code>.</dd> <dt>{{cssxref("repeat", "repeat( [ <positive-integer> | auto-fill | auto-fit ] , <track-list> )")}}</dt> <dd>Представляет собой повторяющийся фрагмент ряда элементов, позволяющий большому количеству колонок (по сути являющихся повторяющейся комбинацией), быть написанной в более компактном виде.</dd> <dt><a href="/ru/docs/Web/CSS/CSS_Grid_Layout/Subgrid">subgrid</a></dt> <dd>Значение <code><dfn>subgrid</dfn></code> означает, что сетка наследует часть родительской сетки, в которой располагается. Вместо явного определения, размеры сетки берутся из определения сетки родительского элемента.</dd> </dl> <div class="blockIndicator warning"> <p>Значение subgrid определено во втором уровне спецификации Grid, и в текущий момент реализовано только в Firefox 71 и более поздних версиях.</p> </div> <h3 id="Формальный_синтаксис">Формальный синтаксис</h3> {{csssyntax}} <h2 id="Пример">Пример</h2> <h3 id="CSS">CSS</h3> <pre class="brush: css notranslate">#grid { display: grid; width: 100%; grid-template-columns: 50px 1fr; } #areaA { background-color: lime; } #areaB { background-color: yellow; }</pre> <h3 id="HTML">HTML</h3> <pre class="brush: html notranslate"><div id="grid"> <div id="areaA">A</div> <div id="areaB">B</div> </div></pre> <h3 id="Результат">Результат</h3> <p>{{EmbedLiveSample("Пример", "100%", "20px")}}</p> <h2 id="Спецификации">Спецификации</h2> <table class="standard-table"> <thead> <tr> <th scope="col">Спецификация</th> <th scope="col">Статус</th> <th scope="col">Комментарий</th> </tr> </thead> <tbody> <tr> <td>{{SpecName("CSS3 Grid", "#propdef-grid-template-columns", "grid-template-columns")}}</td> <td>{{Spec2("CSS Grid")}}</td> <td>Initial definition</td> </tr> <tr> <td>{{SpecName("CSS Grid 2", "#subgrids", "subgrid")}}</td> <td>{{Spec2("CSS Grid 2")}}</td> <td>Adds subgrid</td> </tr> </tbody> </table> <p>{{cssinfo}}</p> <h2 id="Поддержка_браузерами">Поддержка браузерами</h2> <p>{{Compat("css.properties.grid-template-columns")}}</p> <h2 id="Смотрите_также">Смотрите также</h2> <ul> <li>Related CSS properties: {{cssxref("grid-template-rows")}}, {{cssxref("grid-template-areas")}}, {{cssxref("grid-template")}}</li> <li>Grid Layout Guide: <em><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Basic_Concepts_of_Grid_Layout#Grid_Tracks">Basic concepts of grid layout - Grid Tracks</a></em></li> <li>Видео туториал: <em><a href="http://gridbyexample.com/video/series-define-a-grid/">Defining a Grid</a></em></li> </ul> <section class="Quick_links" id="Quick_Links"> <ol> <li><a href="/en-US/docs/Web/CSS"><strong>CSS</strong></a></li> <li><a href="/en-US/docs/Web/CSS/Reference"><strong>CSS Reference</strong></a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout">CSS Grid Layout</a></li> <li data-default-state="open"><a href="#"><strong>Guides</strong></a> <ol> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Basic_Concepts_of_Grid_Layout">Basics concepts of grid layout</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Relationship_of_Grid_Layout">Relationship to other layout methods</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Line-based_Placement_with_CSS_Grid">Line-based placement</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Grid_Template_Areas">Grid template areas</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Layout_using_Named_Grid_Lines">Layout using named grid lines</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Auto-placement_in_CSS_Grid_Layout">Auto-placement in grid layout</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Box_Alignment_in_CSS_Grid_Layout">Box alignment in grid layout</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/CSS_Grid,_Logical_Values_and_Writing_Modes">Grids, logical values and writing modes</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/CSS_Grid_Layout_and_Accessibility">CSS Grid Layout and Accessibility</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/CSS_Grid_and_Progressive_Enhancement">CSS Grid Layout and Progressive Enhancement</a></li> <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout/Realizing_common_layouts_using_CSS_Grid_Layout">Realizing common layouts using grids</a></li> </ol> </li> <li data-default-state="open"><a href="#"><strong>Properties</strong></a> <ol> <li><a href="/en-US/docs/Web/CSS/grid">grid</a></li> <li><a href="/en-US/docs/Web/CSS/grid-area">grid-area</a></li> <li><a href="/en-US/docs/Web/CSS/grid-auto-columns">grid-auto-columns</a></li> <li><a href="/en-US/docs/Web/CSS/grid-auto-flow">grid-auto-flow</a></li> <li><a href="/en-US/docs/Web/CSS/grid-auto-rows">grid-auto-rows</a></li> <li><a href="/en-US/docs/Web/CSS/grid-column">grid-column</a></li> <li><a href="/en-US/docs/Web/CSS/grid-column-end">grid-column-end</a></li> <li><a href="/en-US/docs/Web/CSS/grid-column-gap">grid-column-gap</a></li> <li><a href="/en-US/docs/Web/CSS/grid-column-start">grid-column-start</a></li> <li><a href="/en-US/docs/Web/CSS/grid-gap">grid-gap</a></li> <li><a href="/en-US/docs/Web/CSS/grid-row">grid-row</a></li> <li><a href="/en-US/docs/Web/CSS/grid-row-end">grid-row-end</a></li> <li><a href="/en-US/docs/Web/CSS/grid-row-gap">grid-row-gap</a></li> <li><a href="/en-US/docs/Web/CSS/grid-row-start">grid-row-start</a></li> <li><a href="/en-US/docs/Web/CSS/grid-template">grid-template</a></li> <li><a href="/en-US/docs/Web/CSS/grid-template-areas">grid-template-areas</a></li> <li><a href="/en-US/docs/Web/CSS/grid-template-columns">grid-template-columns</a></li> <li><a href="/en-US/docs/Web/CSS/grid-template-rows">grid-template-rows</a></li> </ol> </li> <li data-default-state="open"><a href="#"><strong>Glossary</strong></a> <ol> <li><a href="/en-US/docs/Glossary/Grid_lines">Grid lines</a></li> <li><a href="/en-US/docs/Glossary/Grid_tracks">Grid tracks</a></li> <li><a href="/en-US/docs/Glossary/Grid_cell">Grid cell</a></li> <li><a href="/en-US/docs/Glossary/Grid_areas">Grid areas</a></li> <li><a href="/en-US/docs/Glossary/Gutters">Gutters</a></li> <li><a href="/en-US/docs/Glossary/Grid_rows">Grid row</a></li> <li><a href="/en-US/docs/Glossary/Grid_column">Grid column</a></li> </ol> </li> </ol> </section>