Сброс в CSS обеспечивает сбалансированность стилей между некоторыми браузерами, а также есть возможность заново приступить к оформлению элементов. Есть два варианта сброса. Первым является применение CSS библиотеки подобные Normalize и так далее, а второй максимально простой:
Итак, сейчас на все составляющие будут распространяться свойства margin и padding, которые равны нулю, а box-sizing: border-box предоставляют возможность уточнять параметры всему блоку, а не только его содержимому.
Пояснение: В случае следования рекомендации «Наследуйте box-sizing», у вас есть возможность не включать функцию box-sizing в ваш CSS Reset.
Пускай box-sizing унаследуется от html:
Именно так гораздо удобнее трансформировать box-sizing в плагинах или иных элементах, которые определяют другой образ действий.
За место того, чтобы добавлять границу.
. а после удалять её с последнего элемента.
. применяйте псевдокласс :not() для того, чтобы добавить к исключительно необходимым компонентам:
Безусловно, у вас есть возможность применять .nav li + li или даже .nav li:first-child
li, но с :not() становится яснее, а селектор CSS описывает края на понятном нам языке.
Совсем необязательно добавлять свойство line-height ко всем <р>, <h*>, и так далее… по одному. Для этого следует добавить его в body:
Тем самым текстовые компоненты совершенно просто смогут унаследовать свойство от body.
Это не чудо, без сомнения вы сможете разместить объекты, как по центру, так и по вертикали:
Желаете дополнительно что-либо еще расположить по центру? Горизонтально, вертикально? Где угодно, как угодно, в любое время? Тогда именно для Вас мы подготовили хорошую статью, которая, безусловно, сможет научить этому.
Пояснение: Обратите внимание на некие баги flexbox в IE11.
Составьте список подобный реальному, разделите его запятыми:
Воспользуйтесь псевдоклассом :not() для того, чтобы не добавлять запятую в заключительный пункт.
Пояснение: Данная рекомендация не постоянно может давать благоприятный итог, к примеру, могут произойти сложности у экранного диктора. Что касается копирования/вставки из браузера, то она также вероятно может быть не рабочей с созданным CSS контентом. Будьте на стороже.
Примените отрицательные показатели в nth-child в CSS для подбора объектов с 1 по n.
Иначе, исходя из того, что Вы слегка ознакомились с :not() можете попытаться:
Итак, это было довольно просто.
Нет ни единого повода, который бы отрицал использование формата SVG для значков полезным:
SVG отлично масштабируется абсолютно для каждого разрешения, и подходит для всех браузеров, включая IE9 и выше. Так давайте выбросим все ваши .png, .jpg или .gif-jif.
Пояснение: в случае если у вас присутствуют кнопки, которые содержат исключительно SVG пиктограммы, и SVG не получается загрузить, тогда это позволит сохранить наличие кнопки:
Несомненно, данное название является странным, но воспользовавшись многофункциональным селектором (*) с соседним селектором (+), мы обретаем мощное правило CSS:
В данном примере мы можем видеть, что все компоненты в структуре документа, получают margin-top: 1.5em.
Для того чтобы более подробно изучить селектор «Лоботомированная сова», предлагаю перейти по статье Heydon Pickering на A List Apart.
Осуществление ползунков на чистом CSS путем использования max-height и overflow hidden:
В момент наведения компонент увеличивается до значения max-height, а всё остальное, что не влезает, можно прокрутить.
Периодически работать с таблицами крайне изнуряющее занятие, в такие моменты, следует попробовать задать table-layout: fixed для того чтобы ячейки стали равной ширины:
В момент работы с пробелами среди колонок у вас есть возможность избежать псевдоклассы nth, first- и last-child, с помощью свойства flexbox space-between:
Отныне пробелы внутри колонок станут единого размера.
Представляйте ссылки тогда, когда элемент <a> пустой, однако имеется ссылка в атрибуте href:
Такой вариант крайне удобен.
Примените для ссылок стиль «по умолчанию»:
Сейчас ссылки, добавленные через CMS, которые обычно не содержат атрибута class, имеют в себе характерный признак, не воздействующий на каскад.
Примените многофункциональный селектор (*) в пределах компонента, для того чтобы сформировать непрерывный вертикальный ритм в CSS.:
Непрерывный вертикальный ритм дополняет визуальной эстетикой, за счет этого чтение текста намного приятней.
Для того чтобы сформировать блок с собственным отношением сторон, вам стоит всего лишь, дополнить верхний или нижний padding к DIV:
Применение padding 20% устанавливает высоту параллелепипеда равной 20% от его ширины. Вне зависимости от ширины окна, дочерний DIV продолжит сохранение соотношение сторон (100% / 20%=5:1).
Перед нами пример как сделать битые изображения эстетически приемлемыми для глаза в CSS.:
Сейчас следует дополнить правилами псевдо-элементы для изображения сообщения пользователю и URL-ссылки битого изображения:
Для более подробного изучения этой модели, предлагаю прочитать исходную статью Ire Aderinokun.
По окончанию того как произвелась установка базового размера шрифта всего проекта (html ), укажите размер шрифта в CSS. для текстовых компонентов через em:
После этого задайте размер шрифта для модулей через rem :
Итак, сейчас любой модуль оказывается разобщенным и элементарней в настройке, тем самым проще в обслуживании.
Данный трюк действенен для пользовательских стилей. Стоит устранять недовольство пользователя звуком из видео, которое автовоспроизводится при загрузке страницы. В том случае если звук не приглушен, то не стоит демонстрировать видео:
И вновь мы использовали псевдокласс :not().
Вот еще один хороший рецепт. Размер шрифта должен подстраиваться под каждый возможный размер экрана. У вас есть возможность подсчитывать размер шрифта, базируясь на таких величинах, как высота и ширина экрана, при помощи :root:
В данный момент у вас есть возможность применить единицу root em на базе значения, подсчитанного посредством :root:
Для того чтобы обойти трансфокации мобильными браузерами (iOS Safari, и др.) компонентов HTML формы, в тот момент, когда открывающийся список <select> нажат, добавьте font-size правило селектору: