изучение принципов работы с сеткой для начинающих
От автора: дни таблиц, маркерные хаки, магия позиционирования и неортодоксальные способы обтекания использовались для достижения желаний макета, и они, наконец, позади. Теперь у нас есть выбор, чтобы использовать самый мощный метод макета, который когда-либо приходил в CSS на сегодняшний день; Grid.
Этот новый метод полностью изменяет подход к макетам для Web и, безусловно, самую важную спецификацию, когда-либо приземляющуюся в CSS. Большинство опытных разработчиков слишком хорошо знакомы с фрустрингами, которые им дали, поскольку CSS был впервые представлен, но новости ярче в наши дни, потому что поддержка огромна. Присоединяйтесь ко мне и читайте CSS Grid руководство.
Принципы работы Grid
Чтобы начать использовать Grid, важно понять основополагающие аспекты. Начнем с определения display:grid в родительском контейнере, который позволяет размещать дочерние элементы вдоль столбцов и строк.
Легкотня, да?
Как только ваша сетка будет определена, вы в хорошей позиции, чтобы начать, но это пока не делает ничего волшебного; мы должны сообщить сетке, как должны стоять большие столбцы и строки. Чтобы лучше ознакомиться с деталями, давайте обсудим терминологию Grid.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееТерминология
Контейнер Grid: родительский контейнер, в котором вы определили отображение сетки
Элементы сетки: прямые дети из вашего сетчатого контейнера
Grid Gap: используется для разметки столбцов и строк. Подумайте о разрывах, как водосточные желоба.
Grid Cell: пространство между двумя соседними строками и двумя соседними столбцами сетки столбцов. Это единственная «единица» сетки.
Область сетки: одна или несколько ячеек сетки, которые составляют прямоугольную область на сетке. Сетки должны быть прямоугольными.
Grid Track: Треки определяются строками, которые запускают и останавливают строки или столбцы, поэтому у вас всегда будет больше, чем у столбцов / строк, которые у вас есть. Другими словами, это пространство между двумя соседними линиями сетки.
Grid Lines: Это разделительные линии, которые создаются при определении отображения сетки.
Неявные и явные линии сетки
Неявные: визуализируется как пунктирные линии в DevTools и создается браузером без явного определения строк / столбцов. Хорошим примером этого может быть перенос строк в новую строку независимо от определенного явного числа. Если у вас есть только две строки, явно определенные в вашем CSS, но ваш контейнер содержит больше элементов, чем вы ожидали, и они начинают перенос в другую строку … это неявно.
Явные: сплошные линии, видимые в DevTools для строк / столбцов, определенных в вашем CSS. Явные сценарии — это не решения, сделанные браузером; это решения, которые вы принимаете … это явное.
Интервал
Для пространственных рядов и колонок (или водосточные желоба) вы будете использовать свойство grid-gap, хотя это свойство должно в конечном итоге быть заменено на gap. Чтобы обеспечить вашу сетку водостоками (пробел), вы определяете это свойство в родительском контейнере.
.parent-container { grid-gap: 20px 20px; /* row gap / column gap */ } .parent-container { grid-gap: 20px; /* row and column gap */ }
.parent-container { grid-gap: 20px 20px; /* row gap / column gap */ } .parent-container { grid-gap: 20px; /* row and column gap */ } |
Первое значение — это пробел в столбце, а второе значение — пробел в строке, но вы также можете передать значение 1 в виде сокращения для разрывов строк и столбцов, которые имеют одинаковое значение.
FR единицы
Значение FR, иначе известное как дробная единица, решает проблему автоматического распределения свободного пространства; это как бы заменяет потребность в процентах.
Создание контейнеров, столбцов и строк сетки
Видя, что ничего не происходит, пока вы не определите строки и столбцы, мы должны начать с того, чтобы узнать, как мы их создаем. Существуют различные способы определения обоих параметров, поэтому давайте начнем с изучения того, как создавать столбцы.
Создание столбцов
Свойство grid-template-columns создается в родительском контейнере, где каждое переданное значение представляет количество явных столбцов. Например:
.parent-container { grid-template-columns: 20px 1fr 40px; }
.parent-container { grid-template-columns: 20px 1fr 40px; } |
Пример выше говорит браузеру «Создайте 3 столбца, пожалуйста! Первый столбец шириной 20 1fr, второй столбец — 1fr , а третий столбец — 40px». Вы также можете передавать функции и ключевые слова в качестве значений, которые мы рассмотрим далее в этой статье.
Существует сокращенное свойство, также называемое grid, но мое предложение — держаться подальше от него, так как его трудно запомнить, сложно читать и время от времени расшифровывать.
Распространение колонок
Метод, известный как spanning, позволяет дочерним элементам растягиваться по столбцам, присутствующим в вашей сетке, определяя начальную / конечную позицию столбца.
.child-item:nth-child(1) { grid-column: span 2; /* span 2 columns */ } .child-item:nth-child(2) { grid-column 4; /* start item at column 4 */ }
.child-item:nth-child(1) { grid-column: span 2; /* span 2 columns */ } .child-item:nth-child(2) { grid-column 4; /* start item at column 4 */ } |
В приведенных выше примерах описываются промежутки столбцов и позиция начала столбца в фундаментальной форме, но вы также можете включить косую черту между двумя значениями.
.child-item:nth-child(1) { grid-column: span 2 / 5; }
.child-item:nth-child(1) { grid-column: span 2 / 5; } |
В приведенном выше коде говорится, что браузер «Распределяет ширину столбца элемента сетки 2 и заканчивается в столбце 5.» Это означает позицию column-start column-end / column-end, но обратите внимание, что мы не сказали браузеру, где следует начинать столбцы; мы только говорили, где закончить.
Это то, что делает браузер. В нем говорится: «Хорошо … вы хотите закончить линию сетки для столбца 5, но также охватите 2 столбца, чтобы ваш объект действительно начинался в конце линии сетки для столбца 2.» Если мы хотим сообщить браузеру, где именно начать дочерний элемент, мы оставим ключевое слово span полностью.
.child-item { grid-column: 2 / 5; }
.child-item { grid-column: 2 / 5; } |
Это говорит браузеру «Начните мой пункт в столбце 2 и закончите в столбце 5.»
Создание строк
Сетки решетки похожи на столбцы, они работают только вертикально, а не горизонтально. Свойство написано идентично нашему столбцу, за исключением того, что вместо этого мы используем слово rows. Вот как это написано в вашем CSS:
.parent-container { grid-template-rows: 1fr 1fr 1fr 1fr; }
.parent-container { grid-template-rows: 1fr 1fr 1fr 1fr; } |
В приведенном выше примере определены 4 явных строки, каждая из которых 1fr высоту. Если какие-либо дети обернут новую строку, когда будут созданы ваши неявные строки.
Row Spanning
С grid-row мы имеем ту же возможность охватить строки, что и мы можем сделать для перекрытия столбцов. С днем рождения все!
.child-item { grid-row: span 2; } .parent-container { grid-row: 1 / 5; }
.child-item { grid-row: span 2; } .parent-container { grid-row: 1 / 5; } |
Подобно тому, как мы делали это для разметки столбцов, мы приближаемся к тому же самому диапазону.
Растягивание на полную ширину
Это значение sneaky -1, которое вы будете использовать часто, чтобы охватить полный контейнер сетки, и все потому, что ваша сетка больше, чем количество определенных столбцов / строк; это действительно связано с треками. Этот трек официально заканчивается в конце вашего контейнера сетки.
.child-item { grid-column: 1 / -1; }
.child-item { grid-column: 1 / -1; } |
Этот пример начинается с первого столбца и охватывает всю ширину определенной сетки независимо от количества столбцов, определенных в вашем CSS. Круто? Да!
Создание строк и столбцов. Короткий путь
Сокращение grid-template позволяет определить начальную и конечную позицию для строк и столбцов в одной строке и гораздо легче читать или использовать свойство grid ранее обсуждавшееся. Я лично предпочитаю это сокращение; это просто имеет смысл для меня.
.parent-container { grid-template: 1fr 1fr / 100px 100px 100px; }
.parent-container { grid-template: 1fr 1fr / 100px 100px 100px; } |
Сокращение, которое мы предоставили выше — это grid-template-rows и grid-template-columns, но у нас также есть области grid-template-areas (подробнее об этом ниже). Первое значение — это начальная позиция, а второе значение — конечная позиция, за которой следует косая черта / которая повторяет этот шаблон. Вы можете думать об этом так: первая часть косой черты — это ваши строки, а вторая часть косой черты — ваши столбцы, но как насчет этих областей шаблонов?
grid-template: «header header header» auto «sidebar1 content sidebar2» 1fr «footer footer footer» auto / 200px 400px 200px;
grid-template: «header header header» auto «sidebar1 content sidebar2» 1fr «footer footer footer» auto / 200px 400px 200px; |
Здесь мы определяем области шаблонов в той же строке, что и размер строки, разделенный косой чертой, которая определяет количество столбцов и их соответствующие размеры, и все делается в одной строке. Коротко и просто; замечательно!
Управление переполнением
Что делать, если у вас есть что надоедливое переполнение, задерживающееся в вашей сетке? Вы бросаете свой компьютер в окно? Неправильно! Вы можете контролировать переполнение сетки одним быстрым действием, используя некоторые тщательно размещенные свойства для переполнения столбцов и строк. Давайте начнем с изучения переполнения столбца.
Переполнение столбца
Есть переполнение? Вам повезло, потому что это одно из тех свойств, которое поможет справиться с вашими потребностями в переполнении. Он определен в родительском контейнере и написан следующим образом:
.parent-container { grid-auto-columns: 2fr; }
.parent-container { grid-auto-columns: 2fr; } |
Насколько велико будет неявное переполнение, но вы должны явно указать CSS, какой тип переполнения должен быть, и в этом случае … столбцы.
webformyself.com
Технология CSS Grid. Руководство по адаптивной верстке
Бондарь Валерия
Ермилова Виталия
Дударев Сергей
Новиков Дмитрий
Юлия Волобой
Хохлов Денис
Хочу выразить благодарность команде WebForMyself.com и отдельно Денису Булыге за видеокурс «Верстка-мастер. От теории до верстки популярных шаблонов». Тезисно, что понравилось:
- Приятный голос автора ;))
- Хороший темп, замечательно рассказывает и все объясняет. Предвосхищает вопросы.
- Отличный выбор шаблонов. Две трендовые работы, которые хочется быстрее сверстать.
Реализация верстки. Я давно не новичок и сверстала более 100 проектов, но многие моменты делала «по-старинке» и была приятно удивлена, как это можно делать проще, быстрее.
Интересно, полезно и без «воды».
Кому бы я порекомендовала данный курс?
- Новичкам обязательно! Все бонусы буквально «разжеваны». Не освоить материал – это надо сильно постараться.
- Продвинутые верстальщики. Вас порадует подход. Денис верстает все с .psd макета. Очень качественно и четко, объясняя все на своем пути.
Денис, я хочу еще один курс на эту же тему, только с другими шаблонами. =)
Как итог, ускорила этап верстки, нашла много «вкусного» в реализации нетипичных блоков. Закрепила работу с препроцессором SESS и обработкой svg-иконок. Попрактиковала верстку под моб. устройства. В дальнейшем планирую создать свой собственный css-фреймворк.
Еще раз спасибо огромное WFM =)
Купленные курсы:
- WordPress-Мастер: от Личного блога до Премиум шаблона
Научилась выстраивать логически структурированную HTML-разметку и работу со стилями CSS. Познала тайны создания шаблона для WordPress.
Начинала почти с нуля. По сайтостроению знания были отрывочные и хаотичные. Не могла выстроить верстку страницы, потому что внимание рассеивалось на множество вариантов «можно сверстать вот так или так… ой что же выбрать, на чем остановиться?»
Что помогло принять решения для покупки курса? Несколько ранее купленных курсов и бесплатных уроков от Андрея Бернацкого и Андрея Кудлая. Некоторые уроки проделывала по 2 раза, чтобы лучше усвоить и запомнить.
Наконец-то научилась выстраивать логическую верстку и легко работать со стилями. Кроме того, много ценных уроков по разным слайдерам и галереям, внедрению их в верстку. До этого было сложно в них разбираться, пугало обилие кода, глаза разбегались и было просто страшно. Сейчас оказалось, что это не так уж страшно.
Запомнилась последовательность, с которой Андрей Бернацкий начинал анализ страницы для верстки. Мне это очень помогло. Затем шаг за шагом из набора символов выстраивалась страничка на которую приятно посмотреть в браузере. И самое главное — в любом браузере. Вот это «волшебство» и запомнилось. Хочется повторить.
Хочу научиться грамотно верстать, применять скрипты, создавать шаблоны для Вордпресс. Я веб-дизайнер, рисовать могу красиво, но хочется большего. Стать специалистом, чтобы оказывать полный цикл создания сайта и хорошо зарабатывать. Совершенствоваться дальше.
Большая благодарность Андрею Бернацкому, Андрею Кудлаю — их уроки, подача материала, живое объяснение во время видео, даже когда что-то не получается у них самих из-за пропущенной запятой 😉 — все это создает особую атмосферу. Хочется подсказать «да вот же запятую забыл, потому не показывает, а я нашла!». Внимание фиксируется еще раз и запоминается навсегда.
Благодаря нескольким курсам я сверстала сайт для заказчика и несколько отдельных страниц, внедряла свой дизайн в шаблоны Вордпресс. И даже удалось кое-что заработать. Но мне этого мало. Хочу совершенствоваться дальше, уже приобрела курс по фреймворку Бутстрап.
Купленные курсы:
- Фреймворк Bootstrap: практика адаптивной верстки от А до Я
Главный результат — перспектива работы и дальнейшего совершенствования для начинающего WEB программиста! Возможность верстать достаточно сложные макеты и создавать сайты без углубленного понимания и знания CSS и JavaScript в современных стандартах HTML5 и CSS3.
До настоящего курса с фреймворком не работал. Писал программы в классическом виде в HTML и CSS.
Какие проблемы я испытывал до приобретения курса? Как я отмечал, полное незнание фреймворка Bootstrap — возможность изучать только по документации прилагаемой к пакету. Да, достаточно хорошей и удобной — но в английской версии, русский перевод ужасен и не точен, даже код кое-где не соответствует оригиналу.
Прослушав вводные уроки бесплатного курса Bootstrap 3, оценив качество материала, способ представления, да и просто лексику автора (Андрей Кудлай) и сравнив с тем материалом, который присутствует в интернете без сомнений решил приобрести курс «Фреймворк Bootstrap: практика адаптивной верстки от А до Я»
Чему я научился, изучив курс? Уверенно ориентироваться в основных разделах фреймворка. Понять, что верстку практически любого макета можно достаточно быстро осуществить средствами Bootstrap.
Что мне запомнилось больше всего из курса? Умение автора разделить материал: о чём необходимо рассказать, возможно даже «разжевать».
Каких результатов планирую добиться через полгода? Вероятно, освоить и другие распространенные Фреймворки, кастомизацию данного приложения в большем объеме для «заточки» под конкретный проект.
И теперь Самое Главное. Курс приобретался в первую очередь для сына. Он аутист с проблемой общения и социальной адаптации. Инвалид 3 группы. Но тем ни менее он заканчивает политехнический техникум по специальности программирование. Сейчас проходит преддипломную практику в компании занимающейся разработкой медицинского программного обеспечения. Имеется возможность продолжить работу в ней, но отличное знание Bootstrap — непременное условие! Поэтому данный курс позволил полностью освоится в возможностях данного фреймворка. Большое спасибо авторам!
Купленные курсы:
- HTML5 и CSS3 с Нуля до Профи
- Корпоративный сайт под ключ
- JavaScript & jQuery с нуля до профи
- Angular 4 c Нуля до Профи. Полное руководство для современной веб-разработки
- 1С-Битрикс. Практика создания веб-проектов
- Фреймворк VUE JS. Полное руководство для современной веб-разработки
- FullStack-Мастер. Разработка CRM-системы на Node.js, Express, Angular6
Вопрос: Сфера деятельности?
Ответ: IT — ERP система «Галактика», программирую на Атлантис (есть сертификаты учебных центров), также могу администрировать данную систему.
Вопрос: Ваш сайт?
Ответ: Своего сайта нет, я пока не нашел, чем бы я мог поделиться с другими.
Вопрос: Ссылки на Ваши социальные сети?
Ответ: Не пользуюсь социальными сетями, только электронной почтой.
Вопрос: Жизненный опыт?
Ответ: Программирую на C#, VBA (хорошее знание объектной модели Word, Excel, Access), раньше писал на Delphi. Последний год-полтора заинтересовался веб-программированием, все началось с верстки сайтов и плавно перетекло в изучение PHP и JavaScript, версткой сейчас не занимаюсь, при необходимости заказываю верстку на fl.ru, я же пишу движок сайта и сажаю на него сверстанные страницы.
Вопрос: Опишите себя в начале пути?
Ответ: В начале пути для меня веб-программирование было «темным лесом», где было страшно и неуютно, но жажда знаний заставила двигаться вперед, да, на Делфи мне приходилось писать парсеры, были написаны Ebay снайпер, программа для участия на тендерах. На данный момент я понимаю, что написать подобное лучше на PHP (не нужно «придумывать велосипед» с библиотекой Synapse).
Вопрос: Опишите себя сейчас?
Ответ: Мне сложно описывать себя сейчас, это все субъективно. Точно могу сказать, что каскадные таблицы стиля и HTML не вводят в ступор. PHP, хоть и не является таким же гибким, как C#, он мне нравится. Уйти с функционального программирования в PHP на ООП не составило труда, язык не сложный, нет множественного наследования — выручают трейты. Ну а в остальном, все так же, как и в других языках, нет сильной типизации — для меня это и плюс, и минус. Ну что еще, не заморачиваюсь с уничтожением объектов, как в Делфи — в PHP работает сборщик мусора.
Вопрос: Что Вы скажете по поводу возражений, с которыми Вы, возможно, сталкивались перед покупкой информационных продуктов, как преодолевали данные возражения (нет денег; у меня не получится; слишком поздно начинать; слишком рано начинать; родственники против; слишком сложно; возможно, какие-либо Ваши возражения)?
Ответ: Я никогда не жалел денег на самообразование, а отговорки типа «поздно начинать» или «я не смогу», для меня не приемлемы — дорогу осилит идущий.
Вопрос: Какую проблему Вы пытались решить, какие проблемы испытывали до приобретения курса?
Ответ: Главной проблемой до приобретения курсов был мой нулевой уровень знаний. Да, конечно, можно на ютубе смотреть кучу бесплатных роликов, тут ты не потратишь денег, но зато потратишь самое ценное — время. На ютуб большинство роликов содержат кучу воды, так как авторы стараются сделать видео максимально длинным, чтобы заработать на рекламе.
Вопрос: О чем Вы думали в начале пути?
Ответ: Нашел через интернет, на тот момент нужно было срочно сделать сайт-галерею, и я приобрел первый курс по верстке. Тот проект я благополучно завалил — не хватало знаний. Сверстать макет я смог, прикрутил даже JQuery, а дальше мои знания закончились, нужна была админка, нужно было хранить где-то данные. Тут произошло мое знакомство с паттерном MVC и желание освоить PHP (с MySQL проблем не было, так как по роду своей деятельности я хорошо знаком с SQL, часто приходится вытаскивать данные из БД в разрезе складов, контрагентов и т.д.).
Вопрос: Вы испытывали какие-то сомнения?
Ответ: Нет.
Вопрос: Какие изменения стали происходить, когда Вы узнали о курсах?
Ответ: Когда я узнал о курсах, изменений никаких не происходило, я просто приобрел сначала один курс и начал изучать, потом второй…. изменения стали происходить во время изучения материала, и эти изменения однозначно в лучшую сторону.
Вопрос: Каков был Ваш первый шаг? Как это было?
Ответ: Мой первый шаг можно описать фразой — «это фиаско, братан» — мне не хватало знаний, а одного курса по верстке было недостаточно…. Сейчас с моими знаниями я, даже не задумываясь, использовал CMS-ку (WordPress, Jumla, Droopal) и за тройку дней сделал бы сайт-галерею, благо плагинов и тем в интернете хоть отбавляй. Даже больше, сейчас я способен сам написать движок для подобного сайта на PHP, но на это уйдет просто чуть больше времени.
Вопрос: Что могло бы случиться, если бы Вы не смогли решить свои проблемы, если бы Вы не воспользовались нашими продуктами?
Ответ: Вряд ли бы что-то серьезное случилось, веб-разработка — это мое хобби, я не беру денег за это, и берусь лишь за то, что мне действительно интересно. Ну, а что касается именно Ваших продуктов, именно они направляли меня в мире веб-разработки, так как в начале пути я был подобен слепому котенку, мои знания были нулевыми, и я не знал, куда идти, и что делать. Я считаю, в начале пути просто необходим наставник, указывающий тебе путь, и этим наставником для меня как раз и стали Ваши курсы. Да, не все сразу получилось, но главное — не сдаваться.
Вопрос: Каких успехов Вы достигли?
Ответ: Каких успехов добился? Буквально за 2 недели написал сайт для сервисных центров Huawei в Казахстане, сейчас этот сайт уже не действует, так как Huawei интегрировали внесение заявок в свою систему. Писал сайт для транспортной компании с возможностью отследить расположение груза онлайн, сайт интернет-магазина, сайт для сестры — она практикующий психолог. Особо-то и хвастаться нечем, это для меня прежде всего хобби.
Вопрос: На какую сумму дохода Вы планируете выйти через полгода?
Ответ: 2500–3000 $ (возможно, такой доход и не будет связан с веб-разработкой).
Вопрос: Как Вы себя чувствуете? О чем думаете? Какие планы?
Ответ: Планы на будущие, наверное, не останавливаться на достигнутом и продолжить изучение новых технологий в веб-разработке. Возможно, попробую себя в мобильных приложениях, если будет хватать времени.
Купленные курсы:
- Angular 4 с нуля допрофи. Полное руководство для современной веб-разработки
- Премиум клуб
- Практика оптимизации сайта. Ускорение загрузки сайта в разы
- JavaScript и jQuery с нуля до профи
- Фреймоврк YII2 с нуля до профи
- Верстка сайта под мобильные устройства
- Фреймворк Bootstrap. Практика адаптивной верстки от А до Я
- Фреймоврк CakePHP с Нуля до Гуру
Этим летом получила первый заказ на верстку.
Идет прогресс, в августе устроилась на работу по специальности HTML-верстальщик в компанию, которая занимается в основном продвижением сайтов, и разработкой тоже. Работаю удаленно, из дома.
Занимаюсь версткой новых блоков (если меняют дизайн), исправлением ошибок в верстке, внесением различных правок в код. Делала верстку блоков для Личного кабинета сайта самой компании.
Оплата сдельная, за каждое выполненное задание. Пока деньги небольшие (получается в среднем 15000 руб в месяц), но для меня это огромный прогресс, что устроилась по специальности, как и хотела!
И самое главное — хорошая практика, которую получаю теперь в большом объеме, работая одновременно с 20 сайтами.
Всё это результат знания из Ваших курсов:
Yii2 — 5 сайтов из 20, с которыми работаю, сделаны на нем — без этих знаний не смогла бы делать необходимые правки.
Хорошее знакомство с устройством cms на уровне разработчика помогает быстро находить нужный код и изменить при необходимости. Приходилось писать небольши е скрипты на php, javascript.
Bootstrap, адаптивная верстка, HTML5, CSS3 — все знания применяются каждый день.
Остальные на OpenCart и WordPress — с ними разбираюсь без проблем.
Я мама двоих девочек 4 и 6 лет — это к вопросу о нехватке времени. Многие считают невозможным совмещать семью, работу и учебу. Да, это непросто, но всё возможно. Главное — огромное желание и упорство! Важно не опускать руки, поскольку при малейших неудачах, а их будет немало, легко бросить любое увлечение, посчитав, что «это не мое».
Как раз трудности — признак того, что вы на верном пути, ведь, преодолев их, вы, действительно, продвинетесь вперед.
Мне помогают мотивирующие книги, ключевой оказалась книга Барбары Шер «Лучше поздно чем никогда». Никогда не поздно начинать, и никогда не нужно думать о «возрасте». Лично у меня нет понятия «в моем возрасте…», и очень странно слышать это от людей моложе, считающих что жизнь почти закончена, и поздно что-либо начинать или менять. Как сильно они заблуждаются.. Не сделав первый шаг уже сегодня, вы его так и будете откладывать, а потом еще неприятнее — жалеть о потерянном времени. Эта книга помогла написать свой план реализации задуманного.
Этот год у меня прошел почти точно по плану. Планировала первый заказ на верстку получить в апреле, в реальности получила его в мае — как я удивилась, насколько это близко к плану, значит все мои действия верны! Планировала устроиться в веб-студию в июле. Устроилась в августе, не веб-студия, но очень близко, ведь работа связана с вёрсткой и корректировкой сайтов.
Читайте побольше, учитесь планировать и организовывать свое время, и, конечно, обращайтесь за советом к профессионалам.
Купленные курсы:
- Фреймворк Bootstrap: практика адаптивной верстки от А до Я
- Практика монетизации блога: от раскрутки до реальных денег
- Фреймворк CakePHP: с нуля до гуру
- Карьера веб-дизайнера. С нуля до первой продажи за 14 дней
- Мастер веб-дизайна 2.0
- Практика верстки под мобильные устройства
- Интернет-магазин под ключ
- Корпоративный сайт под ключ
- Практика резиновой верстки
- Премиум клуб
- Верстка сайта: от основ до конкретного результата
Очень рад, что нашел Ваши курсы в интернете. С удовольствием изучаю их. Конечно, пока рано говорить о конкретных результатах. Я ведь недавно начал свой путь. Но, несмотря на это, уже многое понял, и далее становится все интересней.
Начал с изучения курса «Интернет-магазин под ключ», но позже понял, что нужно вникнуть и в другие тонкости, т.е. в азы программирования, верстки и разметки. Естественно не забыл и о веб-дизайне. В настоящее время очень активно продолжаю изучать уроки PHP из курса «Интернет-магазин под ключ».
Начал с идеи создать свой интернет-магазин и возможно блог. Но как это сделать? Понятно, что есть несколько путей. Первый — быстрый и дорогой. Обратиться к профессионалам. Второй — более доступный и простой, использовать готовую CMS-ку. Третий путь — значительно более длительный и доступный, но дающий по мимо всего прочего конкретные знания мне, которые пригодятся в будущем.
Можно сказать, что начал с полного нуля и своей идеи. Постепенно иду к тому, чтобы реализовать задуманное. Но, в ходе изучения, пришел к тому, что мне интересно не только реализовать задуманное, а возможно и заняться сайтостроением, т.к. интересен и сам процесс.
До приобретения курсов испытывал проблемы как и у многих людей сегодня. Трудности с нормальной работой и ее оплата.
Конечно это не значит, что купив курсы, проблемы сразу куда-то исчезли. Нет. Для того, чтобы проблемы исчезли, или по крайней мере их стало меньше, нужно упорно над собой работать, и стараться реализовать свои идеи. А в процессе изучения к первоначальным задумкам добавляются какие-то новые идеи, появляются новые мысли, и в какой-то момент я понял, что действительно сделал правильный выбор, наконец занявшись чем-то интересным, что может даже приносить хорошие деньги. Но к этому нужно прийти.
После огромного количества потраченного времени в интернете на поиск нужной и недорогой CMS-ки для интернет-магазина, я наткнулся на рекламу Вашего курса «Интернет-магазин под ключ», которая привела меня на Ваш сайт.
Прочитав всю страницу, я понял, что стоит попробовать, приобрел Ваш курс и начал изучение что да как. Пока изучал верстку и разметку, понял, что нужны и другие курсы. Естественно из Вашей линейки, т.к. то как подается материал, мне очень подошло. Воспринимается очень легко и понятно. Практически не возникает вопросов.
Это очень помогает, особенно новичкам, таким как я, у которых вопросов на начальных этапах очень много.
Изучая курс «Интернет-магазин под ключ» я уже понял, что такое веб-дизайн, как по нему делается разметка и верстка будущего сайта интернет-магазина. Сейчас осваиваю уроки по PHP, после которых MYSQL и далее продолжу изучение программирования интернет-магазина.
В процессе изучения курса, становится ясно, что все излагается понятным языком и в легкой для восприятия форме, что очень кстати, особенно если ранее никогда этим не занимался.
Планирую максимально изучить приобретенные курсы, параллельно создавая свой интернет-магазин полностью на всем своем.
От себя хотелось бы добавить небольшое пожелание, если можно так выразиться. Было бы хорошо сделать что-то вроде путеводителя по курсам. Т.е. если человек совсем не имеет понятия с чего начать, но знает что он хочет получить в конце. Т.е. страницу простого и быстрого выбора направления. Например, такой-то курс приведет вас к тому-то, а другой к чему-то другому. Возможно, некоторые курсы будут иметь общие или похожие составляющие результата, которые приводят к одному и тому же, значит человеку будет проще сделать свой выбор.
webformyself.com
CSS Grid Layout. Быстрый старт / Habr
Вступление
Всем привет. Февраль-Март 2017 года запомнились для многих, кто работает с HTML и CSS тем, что большинство браузеров выпустили обновления, среди которых были и обновления для CSS. Теперь можно использовать спецификацию CSS Grid Layout без флагов в следующих браузерах: Firefox 52, Chrome 57, Opera 44, Safari 10.1. Какой из браузеров остался позади, думаю, вы догадываетесь. Точнее он поддерживает старую версию спецификации. Но разработчики этого браузера делают все возможное, чтобы внедрить новую спецификацию. Внедрение поддержки новой CSS Grid Layout спецификации — это самое значимое событие за прошедшие пять лет. Эта спецификация поменяет полностью подход к разработке пользовательских интерфейсов. И это круто.
Я использую Flexible Box Layout
Многие задаются вопросом: «Стоп, я использую flexbox, зачем мне еще какие-то grid’ы?». Вопрос более чем уместен. CSS Grid не заменит Flexbox и наоборот. Первое отличие — это то, что Flexbox работает только в одном измерении. Из этого следует, что мы можем размещать flex элементы только вдоль главной оси или вдоль поперечной оси. Мы не можем разместить flex элементы сразу на нескольких осях. CSS Grid в свою очередь нам позволяет работать с разметкой в двухмерном пространстве и выравнивать содержимое в обоих измерениях. Мне нравится как объясняет эту разницу Tab Atkins.
Одна из самых больших проблем при разработке пользовательских интерфейсов — это то, что при изменении дизайна, функционала или поведения любого блока приходится менять его разметку (в большинстве случаев). CSS Grid позволяет менять расположение grid элементов не меняя сам HTML. Ниже пример простой разметки на Flexbox и CSS Grid.
Основные термины
Прежде чем приступать к работе с CSS Grid, нужно разобраться с основными терминами. На основе этих терминов построена вся спецификация.
Grid container — это набор пересекающихся горизонтальных и вертикальных grid линий, которые делят пространство grid контейнера на grid области, в которые могут быть помещены grid элементы. Внутри grid контейнера есть два набора grid линий: один определяет ось столбцов, другой определяет ось строк.
Grid lines — это горизонтальные и вертикальные разделители grid контейнера. Эти линии находятся по обе стороны от столбца или строки. Автор может задать для данного элемента имя или числовой индекс, которые может использовать дальше в стилях. Нумерация начинается с единицы. Важный нюанс, данный элемент восприимчив к режиму написания, который используется на вашем ресурсе. Например, вы используете Арабский язык или любой другой язык у которого режим написания справа налево, то нумерация линий будет начинаться с правой стороны.
Grid track — это пространство между двумя смежными grid линиями, вертикальными или горизонтальными.
Grid cell — это наименьшая неделимая единица grid контейнера на которую можно ссылаться при позиционировании grid элементов. Образуется на пересечении grid строки и grid колонки.
Grid area — это пространство внутри grid контейнера, в которое может быть помещен один или больше grid элементов. Этот элемент может состоять из одной или более grid ячеек.
Каждый элемент тесно связан друг с другом и отвечает за определенную часть grid контейнера.
Первый CSS Grid макет
Мы разобрались с основными терминами. Пришло время сделать наш первый grid макет. Ничего сложного, простенький макет три строки на три колонки, чтобы разобраться с основами. Ниже вы можете увидеть пример.
В первом варианте из примера мы создаем три колонки размером
150px 1fr 150px
и три строки размером 50px auto 50px
соответственно. Обратите внимание на такие значения: 1fr
, auto
. Давайте разберемся, что это за значения.1fr
— это специальная единица измерения введенная в данной спецификации. Она не измеряется в каких-то конкретных единицах измерения (px
, em
, rem
, др.) Из этого следует, что мы не можем использовать ее вместе с функцией calc()
. Эта единица измерения не может быть меньше единицы, а также не может принимать отрицательные значения. Она рассчитывается после того, как все остальные значения, отличные от fr
, были рассчитаны.
auto
— ведет себя довольно интересно и использует для расчета размеров хитрый алгоритм. В некоторых ситуациях может показаться, что эта единица измерения работает точно также как и fr
. Но это не так. Главное отличие, auto
будет рассчитан до того, как будет рассчитан fr
. Об этом нужно помнить. Вы можете увидеть данное поведение из второго и третьего вариантов примера, который приведен выше.
Для разметки колонок и строк используются следующие правила:
grid-template-columns: 150px 1fr auto;
grid-template-rows: 50px auto 50px;
Сокращенная форма записи выглядит так:
grid-template: 50px auto 50px / 150px 1fr auto;
Типичный шаблон на grid’ах
Давайте сделаем простенький шаблон с которым мы все знакомы. Ничего сложного, шаблон будет состоять из следующих тэгов:
header
, nav
, aside
, article
, footer
. Подавляющее большинство интернет ресурсов использует данный шаблон. Только знаете, даже в таком простом шаблоне наблюдается следующая проблема: «Я дизайнер, я так хочу. Я разработчик, я так не могу». С появлением CSS Grid Layout подобная проблема должна стремиться к нулю.В данном примере мы знакомимся еще с несколькими свойствами CSS Grid Layout. Первое
grid-template-areas
. Оно используется для создания именованных областей grid контейнера, которые не связаны с каким-либо конкретным grid элементом. Синтаксис очень удобен, мы сразу видим какой шаблон получится на выходе. Второе свойство grid-area
. Оно используется для дочернего элемента grid контейнера. Указывает в какую именованную область поместить grid элемент.Давайте рассмотрим первый вариант grid-template-areas
:
grid-template-areas: "header header"
"nav main"
"footer ."
Один или больше идущих подряд символов
.
(точка) имеют особое значение. Если этот символ используется, то браузер его отрендерит как нулевой токен, что в свою очередь означает следующее: на его месте не будет создана именованная область grid контейнера и в нее нельзя поместить grid элемент.Если мы не указали для какого-то дочернего grid элемента свойство grid-area
, браузер автоматически распределит такие элементы. Такое поведение можно увидеть из последнего варианта, приведенного примера выше.
Полезные ссылки
- CSS Grid Layout Module Level 1
- How to create a simple layout with CSS Grid Layouts
- Grid by Example от Rachel Andrew
- Подборка ресурсов для изучения CSS Grid Layout от Jen Simmons
- Ресурс для изучения СSS Grid Layout от Mozilla
- Jen Simmons про CSS Grid CSS Grid Layout
- Моя подборка ресурсов по CSS Grid Layout
- Множество годных статей (как своих авторских, так и переводов) по CSS Grid Layout на css-live.ru
Вместо заключения
В данной статье мы рассмотрели всего лишь верхушку CSS Grid Layout айсберга. Я начал обращать внимание на CSS Grid Layout еще когда все браузеры его поддерживали за флагами. Данный текст не способен передать мои впечатления от работы с этой спецификацией. Иногда сложно поверить своим глазам какие штуки удается сделать при помощи CSS Grid. Это разрыв всех шаблонов. И мне это нравится.
Я вам советую обратить внимание на данную спецификацию и потратить немного своего времени на ее изучение. Поверьте, в будущем вам это точно пригодится и не важно, пишете вы на React, Angular, Vue (вставьте свое). Grid’ы пришли надолго.
Напоследок добавлю пример с произвольным появлением grid элемента в разных именованных областях.
На этом все. Спасибо за внимание. Кто дочитал до конца, отдельное спасибо.
habr.com
Все про grid. Наиболее полное руководство по css grid.
Все про grid. Наиболее полное руководство по css grid.
Здравствуйте! В этой статье я хотел бы обобщить все те свойства grid layout, которые были рассмотрены в предыдущих уроках по верстки на grid. Система grid позволяет задавать направление элементам на странице сразу в 2-х направлениях в отличие от того же Flexboxa где можно задавать только в одном направлении.
Терминология CSS Grid
Прежде чем мы начнем разбираться со свойствами Grid layput давайте познакомимся с некоторыми терминами верстки на гридах.
Контейнер сетки
Контейнер представляет из себя родительский элемент к которому применено свойство display: grid. Например:
<div> <div>Item1</div> <div>Item2</div> <div>Item3</div> </div>
В примере в качестве контейнера используется div с классом container.
Элемент сетки
Каждый вложенный элемент в родительский является элементом сетки. Например:
<div> <div>Item1</div> <div>Item2</div> <div>Item3</div> </div>
В примере каждый div с классом item будет являться элементом сетки.
Линии сетки
Это разделительные линии которые проведены между всеми элементами в сетке. Они могут быть как горизонтальные так и вертикальные.
Трек сетки
Представляет из себя некое пространство между двумя линиями сетки.
Ячейка грида или сетки
Это пространство между двумя соседними клетками в сетке.
Область сетки.
Эта область ограниченная 4-мя линиями в сетке грид.
Итак с основными определениями грида вроде разобрались теперь перейдем непосредственно к свойствам элементов. эти свойства разделяются на свойства родительских элементов и свойства дочерних элементов. Давайте будем разбираться по порядку.
Содержание
Свойства для контейнера
Свойства для дочерних элементов
Свойства для родительского элемента сетки (контейнера).
display
Задает сетку для родительского элемента. Принимает следующие значения:
- grid — формирует сетку как грид
- inline-grid — делает инлайновую сетку на практике это свойство редко применяется
- subgrid — используется в том случае если ваш элемент также является и вложенным элементом в другой сетки, то при задании этого свойства размеры будут взяты у родительского элемента а не буду определять собственный.
.cont { display: grid | inline-grid | subgrid; }
И особенно хочется отметить, что в гридах не будут работать свойства float, clear, vertical-align.
grid-template-columns grid-template-rows
Собственно задают строки и столбцы сетки, то есть определяют размер сетки. Можно задавать как фиксированные значения в px, % так и в относительных единицах, определяющих количество свободного пространства в сетки — fr. Также можно для удобства именовать линии сетки.
.container{ grid-template-columns: 20px 40px auto 50px 40px; grid-template-rows: 35% 200px auto; }
А вот пример с именованными линиями грид.
.container { grid-template-columns: [first1] 20px [line2] 40px [line3] auto [col4-start] 50px [five] 40px [end]; grid-template-rows: [row1-start1] 25% [row1-end1] 100px [third-line] auto [last-line]; }
Да кстати повторяющиеся части вы всегда сможете заменить с помощью функции repeat().
.container { grid-template-columns: repeat(3, 40px [col-start]) 5%; }
С помощью свойства fr можно задать для элемента, чтобы он занимал все свободное пространство. Свободное пространство будет вычислено после подсчета всех фиксированных размеров, а при отсутствии таковых оно будет равномерно перераспределено между всеми элементами.
.cont { grid-template-columns: 1fr 1fr 1fr; }
grid-template-areas
Позволяет для вашего шаблона задать именованные области, которые описаны для дочерних элементов с помощью свойства grid-area. Значения:
- name — имя области
- . — точка означает что ячейка пустая
- none — область не задана
.container { grid-template-areas: "name | . | none | ..." "..."; }
Пример:
.item-1 { grid-area: header; } .item-2 { grid-area: main; } .item-3 { grid-area: sidebar; } .item-4 { grid-area: footer; } .container { grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-rows: auto; grid-template-areas: "header header header header" "main main . sidebar" "footer footer footer footer"; }
Пример создаст сетку из 4 колонок и 3 строк. 1-я строка будет состоять из области header, во 2-й строке будут 2 ячейки main, пустая ячейка и ячейка sidebar и 3-я строка будет полностью состоять из footer.
У каждой строки должно быть одинаковое количество ячеек.
grid-template
Представляет собой сокращенное свойство от свойств grid-template-rows, grid-template-columns, grid-template-areas. Значения:
- none — установит все 3 свойства в их начальное значение
- subgrid — установит grid-template-rows и grid-template-columns в subgrid, а grid-template-areas в начальное значение.
- grid-template-rows/grid-template-columns — задает значения для строк и столбцов сетки грид соответственно
.container { grid-template: [row1-start] 35px "header header header" [row1-end] [row2-start] "footer footer footer" 35px [row2-end] / auto 50px auto; }
grid-column-gap grid-row-gap
Задает отступы между элементами в сетке. Значения:
- size — размер отступа для элементов.
.container { grid-template-columns: 200px 50px 100px; grid-template-rows: 60px auto 80px; grid-column-gap: 20px; grid-row-gap: 10px; }
Следует заметить, что отступы задаются только между колонками и строками, но не задаются для внешних краев элементов сетки.
grid-gap
Сокращенное свойство для grid-column-gap и grid-row-gap. Пример:
.container{ grid-template-columns: 120px 100px 100px; grid-template-rows: 70px auto 70px; grid-gap: 20px 10px; }
Если не задать значение для grid-row-gap, то ему присваивается такое же значение как и для grid-column-gap.
justify-items
Это свойство выравнивает содержимое вдоль оси строки то есть по горизонтали. Значения:
- start — выравнивает содержимое по левому краю
- end — выравнивает содержимое по правому краю
- center — выравнивает содержимое по середине
- stretch — растягивает элементы равномерно
Примеры:
.cont { justify-items: start; }
.cont { justify-items: stretch; }
align-items
Выравнивает содержимое элементов по оси столбцов или по вертикальной оси. Значения:
- start — выравнивает содержимое по верхнему краю
- end — выравнивает содержимое по нижнему краю
- center — выравнивает содержимое по середине
- stretch — растягивает элементы равномерно по высоте, таким образом они заполняют собой всю ячейку по высоте
Примеры:
.cont { align-items: start; }
.cont { align-items: stretch; }
justify-content
Выравнивает сетку вдоль оси строки в случае если размер сетки больше размера контейнера, такое может произойти при установки размеров элементам в пикселах, то есть если вы задаете фиксированные размеры для элемента. Значения:
- start — выравнивает сетку по левой стороне контейнера
- end — выравнивает сетку оп правой стороне контейнера
- center — выравнивает сетку по центру контейнера
- stretch — элементы заполняют всю ширину кониейнера
- space-around — задает одинаковые отступы между элементами и полуразмерные отступы по краям
- space-between — задает одинаковое расстояние между элементами без отступов по краям
- space-evenly — задает одинаковые отступы между элементами и полноразмерные отступы по краям
Примеры:
.cont { justify-content: start; }
.cont { justify-content: space-evenly; }
align-content
Выравнивает сетку вдоль оси столбца в случае если размер сетки больше размера контейнера, такое может произойти при установки размеров элементам в пикселах, то есть если вы задаете фиксированные размеры для элемента. Значения:
- start — выравнивает сетку по верхней стороне контейнера
- end — выравнивает сетку оп нижней стороне контейнера
- center — выравнивает сетку по центру контейнера
- stretch — элементы заполняют всю ширину кониейнера
- space-around — задает одинаковые отступы между элементами и полуразмерные отступы по краям
- space-between — задает одинаковое расстояние между элементами без отступов по краям
- space-evenly — задает одинаковые отступы между элементами и полноразмерные отступы по краям
Примеры:
.cont{ align-content: start; }
.cont { align-content: space-evenly; }
grid-auto-columns grid-auto-rows
Определяет размер созданных элементов, в том случае если они создаются не явно. Значения:
- size — размер элементов в любой доступной едеинице измерения
Чтобы понять как работают эти свойства давайте рассмотрим сетку 2х2.
А теперь представте, что мы с помощью свойств grid-column и grid-row позиционируем элементы следующим образом:
.item-1 { grid-column: 1 / 2; grid-row: 2 / 3; } .item-2 { grid-column: 5 / 6; grid-row: 2 / 3; }
То есть мы указываем элементу .item-2 чтобы он начинался на 5 линии и заканчивался на 6. Поскольку мы ссылаемся на несуществующие линии, то создаются так называемые неявные треки, чтобы заполнить собой пространство. Вот для задания ширины этим трекам и используются свойства grid-auto-columns и grid-auto-rows.
.cont { grid-auto-columns: 80px; }
grid-auto-flow
Когда у вас есть элементы в сетке которые вы явным образом не позиционируете явным образом в сетке. Для размещения этих элементов запускается алгоритм авторазмещения, чтобы их разместить. Значения:
- row — строки заполняются поочередно. Новые строки добавляются при необходимости
- column — столбцв заполняются поочередно. Новые столбцы добавляются в случае необходимости
- dense — пустые пространства в сетке заполняются в случае появления более мелких элементов позже
Примеры:
Пусть есть такой HTML:
<div> <div>item-a</div> <div>item-b</div> <div>item-c</div> <div>item-d</div> <div>item-e</div> </div>
Определим для них сетку с 5 столбцами и 2 строками. Свойство grid-auto-flow установим в row.
.container { display: grid; grid-template-columns: 60px 60px 60px 60px 60px; grid-template-rows: 20px 20px; grid-auto-flow: row; }
И укажем размещения в сетке только для двух элементов.
.item-a { grid-column: 1; grid-row: 1 / 3; } .item-e { grid-column: 5; grid-row: 1 / 3; }
В результате получим такую сетку
Если установить grid-auto-flow в значение column, то получим уже такую сетку.
.container { display: grid; grid-template-columns: 60px 60px 60px 60px 60px; grid-template-rows: 20px 20px; grid-auto-flow: column; }
grid
Сокращенное свойство для всех вышеописанных свойств grid-template-rows, grid-template-columns, grid-template-areas, grid-auto-rows, grid-auto-columns, и grid-auto-flow. Это свойство также задает grid-column-gap и grid-row-gap на их значения по умолчанию. Значения:
- none — задает всем свойствам их значения по умолчанию
- grid-template-rows / grid-template-columns — задает соотвественно значения для grid-template-rows и grid-template-columns.
- <grid-auto-flow> [<grid-auto-rows> [ / <grid-auto-columns>] ] — задает значения для свойств grid-auto-flow, grid-auto-rows и grid-auto-columns соответственно.
Примеры:
.cont{ grid: 200px auto / 1fr auto 1fr; }
Свойства дочерних элементов
grid-column-start grid-column-end grid-row-start grid-row-end
Определяют местоаоложение элемента в сетке grid-column-start/grid-row-start это линия с которой элемент будет начинаться, а grid-column-end/grid-row-end это линия на которой элемент будет заканчиваться. Значения:
- line — может быть любым числом, которое ссылается на прономерованную линию
- span число — элемент, который будет распространяться на некоторое количество ячеек
- spаn имя — элемент будет распространяться до линии с указанным именем
- auto — задает автоматическое расположение элементов
Примеры:
.item-1 { grid-column-start: 1; grid-column-end: five; grid-row-start: row1-start grid-row-end: 3 }
grid-column grid-row
Сокращенное свойство для grid-column-start + grid-column-end, и grid-row-start + grid-row-end. Значения:
- start/end — значения где начинается элемент и где он заканчивается
Примеры:
.item-3 { grid-column: 3 / span 2; grid-row: third-line / 4; }
Небольшая поправка если не указывать значение конечной линии, то элемент будет занимать одну ячейку по умолчанию.
grid-area
Задает название элементу, чтобы можно было на него сослаться с помощью свойства grid-template-areas. Значения:
- name — задает имя для элемента
- <row-start> / <column-start> / <row-end> / <column-end> — можно задавать нумерацию и название линий
Примеры:
.item-4 { grid-area: 1 / col4-start / last-line / 6 }
justify-self
Позволяет выравнивать содержимое элемента вдоль оси строки. Применяется непосредственно к содержимому элемента. Значения:
- start — выравнивает содержимое по левому краю
- end — выравнивает содержимое по правому краю
- center — выравнивает содержимое по середине
- stretch — растягивает элементы равномерно
Примеры:
.item-1 { justify-self: start; }
.item-1 { justify-self: stretch; }
align-self
Позволяет выровнить элемент вдоль столбца. Выравнивается содержимое элемента. Значения
- start — выравнивает содержимое по верхнему краю
- end — выравнивает содержимое по нижнему краю
- center — выравнивает содержимое по середине
- stretch — растягивает элементы равномерно по высоте, таким образом они заполняют собой всю ячейку по высоте
Примеры:
.item-1 { align-self: start; }
.item-1{ align-self: stretch; }
Если вы нашли ошибку, пожалуйста, выделите фрагмент текста и нажмите Ctrl+Enter.
Поделиться
Твитнуть
Поделиться
Также читайте
webdiz.com.ua
CSS Grid: Пятиминутное руководство
Сетка – фундаментальный элемент дизайна любого веб-сайта, а CSS Grid – самый мощный и простой в использовании инструмент для ее создания.
Модуль CSS Grid получил поддержку множества современных браузеров (Safari, Chrome, Firefox) в этом году, так что всем фронтенд разработчикам так или иначе придется освоить эту технологию в брижайшем будущем.
В этой статье мы быстро пробежимся по основам CSS Grid и не будем зацикливаться на всех тех моментах, о которых вам не нужно беспокоиться, пока вы не ознакомитесь с основами.
Ваша первая сетка
Два главных ингридиента CSS Grid – это обертка (wrapper) и элементы, которые она содержит. Обертка – это и есть сетка, а элементы выполняют роль содержимого. Вот пример разметки wrapper’а с шестью элементами:
<div> <div>1</div> <div>2</div> <div>3</div> <div>4</div> <div>5</div> <div>6</div> </div>
Чтобы превратить наш div элемент в сетку нужно всего лишь отобразить его как grid.
Используем CSS свойство display: grid:
.wrapper { display: grid; }
Но пока что ничего не происходит, потому что мы еще не определились с внешним видом нашей сетки. На данный момент этот код просто накладывает 6 div’ов друг на друга.
Колонки и ряды
Чтобы сделать сетку сеткой нам нужно определить колонки (columns) и ряды (rows). Давайте создадим три колонки и два ряда используя свойства grid-template-row и grid-template-column.
.wrapper { display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 50px 50px; }
Введя три значения для grid-template-columns, мы получаем сетку, состоящую из трех колонок. Аналогично для grid-template-rows: 2 значения и две строки.
Значение определяет насколько широкими мы хотим сделать наши колонки (100px) и какой высоты будут наши ряды (50px). Вот результат:
Чтобы вы более четко понимали зависимость между значениями и внешним видом сетки, взгляните на пример ниже.
wordyblend.com
Введение в макет CSS Grid
От автора: при создании сложных сайтов сетки имеют огромное значение. Их значимость в современном веб-дизайне становится ясной, стоит только взглянуть на количество фреймворков, в которые внедрена данная технология для ускорения разработки.
После знакомства со спецификацией CSS Grid Layout вам больше не понадобятся отдельные файлы стилей, если вы захотите работать с системой сеток. Не менее важным плюсом будет то, что вы больше не будете полагаться на свойства типа inline и float для позиционирования элементов на странице. В этом уроке мы изучим основные моменты сеточных систем, а также создадим простой макет блога.
Поддержка в браузерах
На данный момент только IE 10+ и Edge поддерживают спецификацию Grid Layout – на коммерческих сайтах данную технологию использовать пока что нельзя.
В Chrome данную опцию можно активировать через флаг «Experimental Web Platform features» в chrome://flags. В Firefox – флаг layout.css.grid.enabled.
Другой вариант – использовать полифил, и да, полифил CSS Grid Polyfill существует! Вы можете воспользоваться любым из трех описанных вариантов и изучать Grid Layout пока он еще на раннем этапе разработки.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееОбратите внимание: В IE на данный момент работает старая версия спецификации, что означает, что браузер не полностью поддерживает новую спецификацию. Когда мы дойдем до примеров, я рекомендую вам использовать Chrome или Firefox.
Терминология Grid System
Что касается позиционирования элементов, CSS Grid системы – это те же таблицы. Однако данный инструмент намного мощнее и разнообразнее. В данном разделе я расскажу про несколько терминов, которые необходимо будет помнить при работе с сетками:
Единицы измерения fr: с их помощью задается размер свободного пространства. Используется вместе с grid-rows и grid-columns. Из спецификации: «Распределение пространства происходит только после того, как все «длины» или размеры строк и столбцов с контентом достигнут максимальных размеров»
Линии: Линии отмечают границы других элементов. Они бывают как горизонтальные, так и вертикальные. На рисунке ниже 4 вертикальные и 4 горизонтальные линии.
Треки: Треки – пространство между параллельными линиями. На рисунке ниже 3 вертикальных и 3 горизонтальных трека.
Ячейки: Ячейки – строительные блоки сетки. На рисунке ниже всего 9 ячеек.
Области: Область – прямоугольник из произвольного количества ячеек. Т.е. трек – это одновременно и область и ячейка.
Позиционирование элементов в сетке
Начнем с основ. В этом разделе я покажу вам, как с помощью сетки размещать элементы в определенных местах. Для работы с CSS Grid Layout необходимо создать родительский элемент и один или более дочерних. Для примера я возьму разметку ниже:
<div> <div>A</div> <div>B</div> <div>C</div> <div>D</div> <div>E</div> <div>F</div> </div>
<div> <div>A</div> <div>B</div> <div>C</div> <div>D</div> <div>E</div> <div>F</div> </div> |
Для создания сетки контейнеру необходимо указать свойства display:grid или display:inline-grid, а также другие стили:
.grid-container { display: grid; grid-template-columns: 200px 10px 0.3fr 10px 0.7fr; grid-template-rows: auto 20px auto; }
.grid-container { display: grid; grid-template-columns: 200px 10px 0.3fr 10px 0.7fr; grid-template-rows: auto 20px auto; } |
С помощью свойств grid-template-columns и grid-template-rows задается ширина строк и колонок. В примере выше я создал 5 колонок. Колонка шириной 10px используется в качестве разделителя между элементами. Первая колонка имеет ширину 200px. Третья колонка занимает 0.3 части от оставшегося пространства. А пятая колонка занимает 0.7 от оставшегося пространства.
Так как первой строке задано свойство grid-template-rows: auto, это позволяет строке расширяться при добавлении контента. Строка в 20px работает как разделитель. В демо ниже видно, что элементы плотно прижаты друг к другу.
Обратите внимание на элемент В – он расположен во второй колонке, которую мы используем как разделитель. Если позиционирование элементов не задано вручную, браузер разместит элементы в ячейках слева направо, и если они не уместились в один ряд, то оставшиеся перепрыгнут на вторую стоку. Вот почему мы оставили 4 запасных колонки на второй строке.
Чтобы переместить элемент в заданную ячейку сетки, необходимо задать позиционирование данного элемента через CSS. Прежде чем я объясню, как двигать элементы сетки, взгляните на рисунок ниже.
В этом примере мы будем использовать линейную систему размещения элементов. Линейная система означает, что линии в сетке будут играть главенствующую роль при размещении элементов. В качестве примера возьмем элемент В. Горизонтально данный блок начинается на третьей линии и заканчивается на 4 линии колонок. Кроме вертикальный линий данный элемент расположен между линий на первом и втором ряду.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееДля того, чтобы задать стартовую вертикальную линию элемента мы воспользуемся свойством grid-column-start. В нашем случае значение будет 3. Свойство grid-column-end указывает на конечную вертикальную линию элемента. В нашем случае это 4. Значения для горизонтальных линий выставляются таким же образом.
На основе вышесказанного делаем вывод, что для перемещения элемента В во вторую ячейку необходимо использовать код:
.element-b { grid-column-start: 3; grid-column-end: 4; grid-row-start: 1; grid-row-end: 2; }
.element-b { grid-column-start: 3; grid-column-end: 4; grid-row-start: 1; grid-row-end: 2; } |
Точно так же для перемещения элемента F в шестую ячейку необходимо:
.element-f { grid-column-start: 5; grid-column-end: 6; grid-row-start: 3; grid-row-end: 4; }
.element-f { grid-column-start: 5; grid-column-end: 6; grid-row-start: 3; grid-row-end: 4; } |
Создаем базовый макет
Сейчас мы создадим базовый макет блога, в котором будут хедер, футер, сайдбар и два секции под контент. Сперва разметка:
<div> <div>Header</div> <div>Sidebar</div> <div>Main Content</div> <div>Extra Info</div> <div>Footer</div> </div>
<div> <div>Header</div> <div>Sidebar</div> <div>Main Content</div> <div>Extra Info</div> <div>Footer</div> </div> |
Помните, что порядок размещения тегов в разметке никак не влияет на позиционирование элементов на веб-странице. Не меняя CSS, вы можете поставить футер в разметке выше хедера, но позиционирование элементов все равно останется прежним. Но я не советую так делать. Основная мысль тут в том, что разметка больше не говорит вам, где будет расположен элемент.
Нам осталось определить значения свойств типа grid-row-end для всех элементов. Как и в предыдущем примере, мы воспользуемся сеточной диаграммой, чтобы определить значения свойств.
Из рисунка выше видно, что хедер расположен между линий колонок 1 и 4 и линий рядов 1 и 2. CSS код хедера будет следующим:
.header { grid-column-start: 1; grid-column-end: 4; grid-row-start: 1; grid-row-end: 2; }
.header { grid-column-start: 1; grid-column-end: 4; grid-row-start: 1; grid-row-end: 2; } |
По тому же принципу «extra content» находится между линий колонок 3 и 4 и линий рядов 5 и 6. И CSS будет:
.extra { grid-column-start: 3; grid-column-end: 4; grid-row-start: 5; grid-row-end: 6; }
.extra { grid-column-start: 3; grid-column-end: 4; grid-row-start: 5; grid-row-end: 6; } |
Теперь вы с легкостью можете вычислить оставшиеся свойства. Взгляните на CodePen демо – чтобы лучше понять принцип линейной системы позиционирования, можете поиграться со значениями свойств:
Заключение
С помощью спецификации CSS grid layout можно с легкостью создавать сложные макеты. CSS код данного способа отличается простотой и удобством. При создании сложных макетов дизайна больше не нужно использовать свойство float или другие подобные свойства. Также преимущество в полном разделении разметки и макета. CSS Grid Layout предоставляет безграничные возможности.
Автор: Nitish Kumar
Источник: http://www.sitepoint.com/
Редакция: Команда webformyself.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееPSD to HTML
Практика верстки сайта на CSS Grid с нуля
Смотретьwebformyself.com
Знакомимся с CSS Grid
От автора: эта неделя ознаменовала выход CSS Grid в последних версиях Firefox и Chrome без дополнительного флага, что стало настоящим праздником для front-end разработчиков. Теперь можно играться с Grid в двух последних версиях этих браузеров. Но что такого в этой CSS Grid, нужна ли она нам?
CSS Grid – первая настоящая система макетирования для веба. Система спроектирована для организации контента в колонки и ряды. У разработчиков буквально появился режим Бога по контролю за экраном. Это значит, что можно выбросить десятилетия хаков и обходных решений по расстановке элементов на веб-странице. Сложные макеты и красивые страницы теперь не просто реальны, теперь их легко создавать и обслуживать.
С CSS Grid веб станет гораздо более привлекательным местом.
Понятно, а как работает Grid? В сети полно сложных уроков с ужасающим количеством информации. Я считаю, что начать нужно с самых основ. Сегодня мы создадим довольно простой пример с буквами из алфавита.
Для начала добавим разметку:
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнее<div> <div> A </div> <div> B </div> </div>
<div> <div> A </div> <div> B </div> </div> |
Первым делом мы добавим правильные стили буквам (font-size и color). Далее центрируем буквы внутри div’ов с помощью flexbox-свойств align-items и justify-content. И да, CSS Grid не заменяет flexbox-свойства, а дополняет их. Многие из этих свойств можно использовать в паре с CSS Grid. А сейчас вернемся к демо:
В примере выше два простых div’а, расположенных один под другим (по умолчанию display: block). Необходимо сделать так, чтобы родительский элемент использовал макет Grid:
.wrapper { display: grid; }
.wrapper { display: grid; } |
Что дает нам:
Видно, что ничего не видно. И все правильно! В отличие от display: inline-block; или display: inline; со значением grid не все так понятно. Чтобы сетка хоть как-то себя показала, ей нужно скормить несколько колонок и рядов. В этом примере мы просто выровняем буквы рядом в две колонки:
.wrapper { display: grid; grid-template-columns: 1fr 1fr; grid-column-gap: 1px; background-color: black; }
.wrapper { display: grid; grid-template-columns: 1fr 1fr; grid-column-gap: 1px; background-color: black; } |
Давайте разберем код. Сперва мы создаем две колонки в сетке с помощью grid-template-columns. Значение 1fr может показаться неправильным, если вы раньше его не видели. Но все верно, это значение говорит, что колонки будут занимать всю свою ширину в сетке. В нашем примере это значит, что будет две колонки одинаковой ширины.
В итоге получится что-то похожее:
Ура, работает! Видите этот пробел между колонок? Это виден фон wrapper, проскакивающий сквозь letter, так как мы задали grid-column-gap в 1px. Обычно приходится задавать большее значение column-gap, особенно если мы выравниваем блоки рядом. Но в нашем примере хватит и 1 пикселя.
Что будет, если мы добавим две новые буквы в разметку? Что изменится в макете?
<div> <div> A </div> <div> B </div> <div> C </div> <div> D </div> </div>
<div> <div> A </div> <div> B </div> <div> C </div> <div> D </div> </div> |
Технически в сетке ничего не изменится. Мы уже задали две колонки, и эти две буквы лягут ровно под другими и будут точно 1fr в ширину:
Теперь что странно, почему между буквами А и С, а также В и D нет пробела в 1px? Свойство grid-column-gap используется только для колонок, и так мы создали новую строку в сетке. Чтобы увидеть изменения, нужно воспользоваться свойством grid-row-gap:
.wrapper { grid-column-gap: 1px; grid-row-gap: 1px; /* другие стили */ /* также можно было использовать сокращение `grid-gap` */ }
.wrapper { grid-column-gap: 1px; grid-row-gap: 1px; /* другие стили */ /* также можно было использовать сокращение `grid-gap` */ } |
Вот так это выглядит:
Вот мы и создали нашу первую сетку. Мы создали строки и колонки, для этого нам потребовалось лишь изменить разметку. Давайте разберем колонки поподробнее. Что будет, если изменить значение свойства grid-template-columns? Вот так:
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнее.wrapper { grid-template-columns: 1fr 1fr 1fr; }
.wrapper { grid-template-columns: 1fr 1fr 1fr; } |
Мы создали еще одну колонку, все ясно! Обратите внимание, что мы теперь свободно видим фоновый цвет контейнера, так как не хватает дочерних элементов:
Если изменить значение fr в этом свойстве, то у нас получится так называемая ассиметричная сетка. Например, давайте сделаем так, чтобы первая колонка занимала в три раза больше места, чем другие две:
.wrapper { grid-template-columns: 3fr 1fr 1fr; }
.wrapper { grid-template-columns: 3fr 1fr 1fr; } |
Колонка с буквами А и D стала больше других, как и ожидалось:
Разве это не сильно? Больше не нужно подбирать отрицательные margin’ы и идеальные значения в процентах, чтобы правильно выровнять колонки. Можно создавать супер сложные сетки, не думая о вычислениях, которые нам пришлось бы делать раньше. Теперь нужно всего лишь добавить новое значение свойству grid-template-columns и все, магическим образом в сетке появляется новая колонка!
Вы можете задаться вопросом насчет адаптивных сеток. Все так же просто, нужно лишь менять это свойство внутри медиа запроса. Например, нам нужно по умолчанию иметь 2 колонки. На уровне 500px колонок должно быть 3, а на больших экранах весь контент перемещается в 4 колонки. Для этого нам потребовалось бы написать следующий код:
.wrapper { display: grid; grid-template-columns: 1fr 1fr; @media screen and (min-width: 500px) { grid-template-columns: 1fr 1fr 1fr; } @media screen and (min-width: 800px) { grid-template-columns: 1fr 1fr 1fr 1fr; } }
.wrapper { display: grid; grid-template-columns: 1fr 1fr;
@media screen and (min-width: 500px) { grid-template-columns: 1fr 1fr 1fr; }
@media screen and (min-width: 800px) { grid-template-columns: 1fr 1fr 1fr 1fr; } } |
Откройте демо в новой вкладке и измените размер вьюпорта, чтобы проверить адаптивность!
Свойство grid-template-columns намного сложнее, чем то, что я здесь показал, но это хорошая отправная точка. Далее нужно изучить свойство из спецификации CSS Grid, которое реально меняет что-то: grid-template-rows.
Давайте смотреть. Давайте попробуем догадаться, что делает это свойство. Посмотрите на код ниже и вспомните все, что знаете о Grid.
.wrapper { display: grid; grid-template-columns: 3fr 1fr 1fr; grid-template-rows: 1fr 3fr; }
.wrapper { display: grid; grid-template-columns: 3fr 1fr 1fr; grid-template-rows: 1fr 3fr; } |
Вместо установки ширины колонок и их взаимосвязей мы теперь задаем высоту строк и их отношения. Так что если взять предыдущий пример и задать последнее значение в 3fr, то вторая строка всегда будет в три раза больше по высоте, чем первая:
Вроде бы ничего сложного, но раньше мы так делать не могли. Раньше приходилось писать грубые хаки. Например, устанавливать min-height на определенном элементе или менять класс. Но у нас не было возможности устанавливать связи между строками. Это и делает CSS Grid мощным инструментом.
С такими небольшими знаниями и парочкой новых свойств мы можем создавать настолько сложные макеты, что ассиметричные и адаптивные сетки будут составлять лишь небольшую их часть. И это лишь верхушка айсберга спецификации CSS Grid, там очень много нового. Jen Simmons лучше всего описала новый инструмент в своей статье:
«CSS Grid нужно изучать до тех пор, пока мы не поймем, что с его помощью нужно делать, что с его помощью можно сделать принудительно, а также что нельзя сделать. Многим дизайнерам можно даже не изучать CSS, но вам нужно хорошо знать CSS, чтобы понимать художественную среду.»
Конечно, код сверху первое время будет казаться странным. Однако теперь нам не нужны гигантские CSS фреймворки и все эти хаки для макетов, которые совсем не актуальны. Что меня больше всего радует в Grid, это то, что он заставляет нас смотреть на пространство в браузере по-другому.
Нам нужно выучить не только кучу новых свойств, но и переосмыслить все, что узнали в прошлом. CSS Grid – это не просто спецификация, а целая философия.
Давайте изучать ее вместе!
Поддержка в браузерах
Данные о поддержке взяты с сайта Caniuse, где также сказано, что функция находится в статусе W3C Candidate Recommendation.
Автор: Robin Rendle
Источник: https://css-tricks.com/
Редакция: Команда webformyself.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееPSD to HTML
Практика верстки сайта на CSS Grid с нуля
Смотретьwebformyself.com