Как убрать стили браузера и зачем нужно сбрасывать CSS, файл reset.css
09.07.18 ИТ / CSS 10777
Современные браузеры содержат свои базовые стили CSS для многих элементов, это можно заметить, открыв консоль разработчика и наведя на любой элемент — в консоли отобразятся его стили, даже если Вы ничего не прописывали. Помечаются они обычно надписью «user agent stylesheet». Это и есть родные стили браузера, которые он применяет к элементам. Зачем нужно их сбрасывать и всегда ли следует это делать?
CSS позволяет задать нужное оформление любой странице, без него код на HTML выглядел бы уныло. Действительно, CSS практически полностью отвечает за внешнее оформление любого тега, ведь тег – это всего лишь кирпичик, стоит убрать у него стили, от него останется нативный каркас с функциональной составляющей. Зачем браузеры добавляют свои стили к элементам HTML? Как раз по это причине. Ведь если не будут добавлены базовые стили, на них страшно будет смотреть, пусть даже Вы и разработчик, всё содержимое попросту склеится и наедет друг на друга.
Производители браузеров стремятся составлять базовые стили CSS таким образом, чтобы элементы выглядели стандартизовано. Разные движки и производители стараются использовать одинаковые таблицы стилей, чтобы во всех браузерах не было колоссальных различий в оформлении тегов. Часто можно управлять некоторыми стилями прямо из настроек браузера, например, можно задать цвет ссылок. Это и есть базовые стили CSS браузера.
Итак, мы разобрались для чего браузер добавляет свои стили к элементам HTML. Но иногда нужно убрать стили браузера и применить свои. Это может понадобится для создания уникального оформления элементов, создания необычного дизайна. И тут базовые стили браузера могут помешать.
Как сбросить стили браузера, а точнее удалить их? Раньше часто можно было увидеть на многих сайтах подключение файлов reset.css, в которых содержались огромные перечисления элементов HTML, для которых перечислялись сбрасывающие свойства.
Эти свойства по сути просто обнуляли отступы, дизайн и т.д. Но использование файла reset.css не самый лучший вариант, так как это подключение лишнего файла, а значит и замедление скорости загрузки сайта. Но это не все, на составление таких стилей придется потратить немало времени, а потом может выясниться, что этот файл только мешает и сбивает с толку при верстке.Поэтому, в настоящее время нет необходимости составлять отдельные файлы для сброса стилей. При разработке достаточно смотреть в консоль разработчика и обнулять нужные свойства путем переопределения стилей – нужно просто задать свое свойство CSS для тега, предыдущее будет отменено. Для некоторых базовых тегов, можно в общем файле стилей Вашего сайта сделать сброс их основных свойств. Таким образом, сброс стилей браузера
Как удалить неиспользуемый код CSS в WordPress
Неиспользуемый CSS – это код, который загружается при открытии страницы, но фактически не исполняется. Например, если вы поставили плагин для контактной формы, то часть его стилей будет загружаться на всех страницах сайта, даже если на них нет самой формы.
Неиспользуемый код CSS на WordPress тащат и установленные темы. Разработчики делают их универсальными. Это полезно для гибкой настройки, но CSS-файлы из-за универсальности сильно разрастаются.
Основные термины:
- Язык CSS – это формальный язык описания внешнего вида веб-страницы или любого другого документа, написанного с использованием языка разметки.
- CSS-стили – это совокупность правил, которые применяются в проекте и определяют способ отображения его элементов.
Например, разработчики тем указывают в style CSS, что это должно быть круглым и зеленого цвета, а вот это – написано полужирным курсивом.
Чем плох неиспользуемый CSS
Загружая неиспользуемый CSS, вы заставляете пользователей тратить время и сетевые ресурсы впустую. Посетители ждут, когда загрузится огромный файл, который на нужной им странице используется на 10-15%. Поэтому CSS – это не так просто, как может показаться на первый взгляд. Чтобы неиспользуемого кода было меньше, нужно думать о структуре проекта и таблиц стилей.
Конечно, файл CSS – это не самый большой пожиратель трафика. Но в совокупности даже такие мелочи приводят к снижению скорости загрузки страницы, понижению рейтинга сайта в поисковых системах и оттоку пользователей.
Комьюнити теперь в Телеграм
Подпишитесь и будьте в курсе последних IT-новостей
Подписаться
Как определить, есть ли на моем веб-сайте неиспользуемый CSS
Самый простой способ – использовать гугловский сервис PageSpeed Insights. Он помогает найти CSS и JS, которые не используются на указанной странице. Однако это не значит, что они не нужны и их можно удалять. Возможно, они требуются для корректной работы других страниц. Результаты анализа PageSpeed Insights – лишь способ увидеть направление, в котором нужно искать неиспользуемый CSS.
Еще можно найти CSS, который не используется, через инструменты разработчика – Chrome DevTools.
-
Откройте страницу, которую хотите проверить, в браузере Google Chrome.
-
Запустите Chrome DevTools (F12 на Windows, Ctrl+Cmd+I на OS X и Ctrl+Shift+I на Linux).
-
Раскройте меню, выделите пункт More Tools и выберите Coverage.
-
Нажмите на кнопку перезагрузки страницы, чтобы инструмент Coverage мог проверить CSS и JS.
Внизу вы увидите результаты проверки: CSS стили WordPress, скрипты JS, а также процент их использования на текущей странице.
Например, на скриншоте показано, что CSS-код из файла используется только на 30%. Но это не значит, что остальные 70% надо обязательно удалять. Возможно, они отвечают за то, чтобы на других страницах работали виджеты или контактные формы.
Оба способа (через PageSpeed Insights и Chrome DevTools) идеально подходят только для проверки одностраничников.
Когда страниц много, количество зависимостей в коде может быть таким, что бездумная очистка CSS становится опасной – можно ненароком удалить нужные стили.Как безопасно удалить неиспользуемый CSS с помощью плагинов
Если речь идет о небольшом проекте, тему которого вы написали с нуля или просто знаете досконально, то можно удалять неиспользуемый CSS вручную. Однако на практике это практически нереальная ситуация.
Ручное удаление занимает кучу времени – часто разработчики после анализа приходят к выводу, что дешевле будет сделать редизайн и переписать стили с нуля.
Если редизайн – не ваше решение прямо сейчас, а удалить неиспользуемый CSS все равно нужно, попробуйте один из представленных ниже плагинов или инструментов. С их помощью поиск CSS станет проще и безопаснее.
Asset CleanUp
Asset CleanUp – один из самых популярных плагинов для WordPress, который помогает находить и безопасно удалять неиспользуемый CSS. Установить его можно из бесплатного каталога в панели администратора. После активации он появится в боковом меню.
Чтобы избавиться от CSS с помощью Asset CleanUp:
-
Перейдите в раздел Settings.
-
Выберите пункт Test Mode и включите одноименный режим. Это нужно для того, чтобы изменения не сказывались на опыте посетителей сайта.
-
Примените изменения – для этого нажмите на кнопку Update all settings.
После включения режима Test Mode перейдите на вкладку CSS & JS Manager в настройках плагина. В подразделе Home вы увидите список CSS-файлов, которые загружаются на домашней странице сайта.
Если вы видите в списке файл, который вам не нужен на домашней странице, то активируйте в его параметрах слайдер Unload on this page. Чтобы применить изменения, нажмите на кнопку Update.
Например, на главной странице сайта нет ни одной контактной формы. При этом плагин загружает файлы, нужные для отображения таких форм. Самое простое решение – отменить CSS-стили формы на всех страницах, где она не нужна.
Сложность в том, что перебирать вручную придется все страницы и посты сайта. Автоматизировать этот процесс с помощью Asset CleanUp нельзя. Кроме того, не забывайте после каждого отключения файлов CSS и JS проверять работоспособность страницы – могут быть сбои из-за неочевидных зависимостей.
CSS JS Manager
CSS JS Manager – еще один бесплатный плагин для управления CSS в WP. Он позволяет через панель администратора удалять ненужные файлы со стилями и JS-скриптами на выбранной странице или на всем сайте.
-
Установите и активируйте плагин.
-
Перейдите в его настройки.
-
Укажите название и тип файла.
-
Выберите метод Async или Normal – это не имеет значения, так как мы будем удалять файл.
-
Выберите действие – Remove this.
-
Выберите цель – On All Pages (На всех страницах) или On Selected Page (На выбранной странице).
-
Нажмите на кнопку Save для применения изменений.
Этот плагин не показывает, какие стили используются, а какие – нет. Его предназначение – простое добавление и удаление файлов CSS и JS. Поэтому пользоваться им нужно очень аккуратно, чтобы случайно не стереть критичные для работы сайта стили и скрипты.
RapidLoad
Самостоятельно находить и удалять CSS, который не используется, умеет плагин RapidLoad. Это расширение для оптимизации сайта на WordPress.
RapidLoad обещает уменьшить размер файлов CSS до 95% при загрузке каждой страницы. Плагин проверяет стили и убирает селекторы, которые не нужны в данный момент. И так происходит при загрузке каждой страницы. В итоге пользователи практически не тратят ресурсы на неиспользуемый CSS.
Разработчики предупреждают, что существует вероятность повредить страницы при автоматическом удалении стилей.
Чтобы избежать этого, можно настроить безопасный список, для которого будет действовать правило загрузки только оригинальных файлов CSS.RapidLoad – платный плагин. Подписка стоит от 10 до 100 долларов в месяц. Выбор зависит от того, на каком количестве сайтов вы будете использовать это расширение.
-
10 долларов в месяц – 1 сайт и поддомены.
-
40 долларов в месяц – 5 сайтов и поддомены.
-
100 долларов – 25 сайтов и поддомены.
При покупке подписки на год применяется скидка до 50% в зависимости от выбранного тарифного плана.
Инструменты разработчика для удаления неиспользуемого CSS
PurgeCSS
PurgeCSS – инструмент для разработчиков, который позволяет отменить стиль CSS, если он не используется. Он анализирует код, сопоставляя селекторы. Стили, которые не используются, удаляются. Это позволяет уменьшить размер файла.
Если вы собираетесь использовать PurgeCSS на WordPress, то вам нужно обязательно создать безопасный список с классами, созданными CMS. Все они содержатся в purgecss-with-wordpress. Кроме того, вы можете указать в списке дополнительные классы, которые PurgeCSS не должен удалять.
PurifyCSS
PurifyCSS – инструмент, который выполняет поиск HTML/CSS и соотносит разметку файлов с реально используемыми стилями. Те селекторы, применение которых не обнаружено, удаляются.
PurifyCSS не меняет исходники. Можно записать стили после очистки в минифицированный CSS-файл. Это особенно полезно при использовании различных CSS-фреймворков, например Bootstrap.
К сожалению, PurifyCSS не подходит для анализа динамических сайтов – например, тех, на которых контент генерируют движки типа WordPress. Его можно использовать только для статистических файлов – допустим, при самостоятельной разработке темы.
UnusedCSS
UnusedCSS – это сервис, который принимает ссылку на страницу, находит неиспользуемые стили и возвращает CSS-файлы без них.
Это платный инструмент. Стоимость подписки – от 25 до 75 долларов в месяц. От тарифа зависит, какое количество сайтов и сколько раз в месяц можно проверить, есть ли проверка по расписанию и другие фишки. Бесплатно можно только проверить сайт и посмотреть пример чистого CSS.
UnCSS
UnCSS – еще один инструмент, который обнаруживает и удаляет неиспользуемый CSS-код. Для этого он берет файл с HTML-разметкой и анализирует таблицы стилей. Отфильтровываются те селекторы, которых нет в HTML. Остальные конвертируются обратно в CSS.
К сожалению, на WordPress неиспользуемые стили CSS нельзя удалить с помощью UnCSS. Он умеет работать только с HTML-файлами. Единственный вариант – сгенерировать из шаблонов каждой страницы стандартную HTML-разметку.
У UnCSS есть онлайн-версия, которую удобно использовать для тестирования. Сервис предлагает вставить в одно поле HTML-разметку, а в другое – стили CSS. После обработки вы получаете сокращенный код CSS, из которого удалены селекторы, неиспользуемые в HTML-разметке.
Заключение
Сервисы и инструменты для удаления неиспользуемого кода CSS помогают, но полагаться только на них нельзя. Автоматизированные инструменты могут ошибочно удалять селекторы, которые нужны для работы отдельных элементов сайтов.
На WordPress лишний HTML и CSS удобно проверять с помощью плагинов. Но и здесь нужно быть осторожным при использовании автоматической очистки. Самый безопасный способ – ручное отключение файлов, помеченных как неиспользованные, и проверка работоспособности отдельных страниц.
селекторов css — CSS удаляет все общие стили из элементов
Есть ли простой способ удалить любые стили из моих элементов, которые применяются к «универсальным» селекторам?
Под общим я подразумеваю раздел
или p
или div
или кнопку
… в основном, когда он не нацелен на элемент на основе класса или идентификатора, а на основе самого фактического элемента.
Проблема в том, что у меня есть некоторые HTML и CSS, которые я вывожу на веб-сайте пользователя, но я не могу контролировать их таблицу стилей, загружаемую на той же странице. Проблема заключается в том, что пользовательская таблица стилей или пользовательский CSS нацелены на базовые общие элементы HTML (например, раздел
или кнопка
или р
). В моем коде есть все определенные селекторы CSS, предназначенные для них, но иногда сайты с таким «общим» стилем вызывают проблемы с отображением моего HTML, если я специально не определил свойство.
Например, мне не нужны какие-либо специальные отступы для элемента p
— поэтому у меня нет ничего, установленного для padding
для моих элементов p
.. но если таблица стилей пользователя делает — это применяется к моему элементу. Я пытаюсь не определять каждое отдельное свойство для каждого элемента моего , просто чтобы убедиться, что таблица стилей пользователя не применяется к моим элементам.
Думал о чем-то вроде этого псевдокода:
#my-main-wrapper > section, p, div, button { все: снято; }
Где будут отменены все стили, которые применяются к любым элементам внутри элемента #my-main-wrapper
с использованием базовых селекторов, таких как section
или p
или div
или кнопка
. . таким образом, применяются ТОЛЬКО те стили, которые я определил для тех элементов, которые используют определенный класс или идентификатор.
- css
- css-селекторы
2
#my-main-wrapper section,p,div,button{ маржа: 0; заполнение: 0; граница:0; }
Если я правильно понял вашу проблему, стоит попробовать это простое решение. Добавьте еще стили, которые, по вашему мнению, могут испортить вашу таблицу стилей, но, по моему мнению, этого должно быть достаточно.
Как упомянул другой пользователь, все: начальный
также может быть хорошим решением. Но обязательно прочитайте это, прежде чем применять это свойство, так как многие люди в конечном итоге неправильно его понимают.
Да, в этой ситуации я бы сделал общий сброс CSS, например:
#my-main-wrapper > * { все: снято; }
3
Зарегистрируйтесь или войдите в систему
Зарегистрируйтесь с помощью Google
Зарегистрироваться через Facebook
Зарегистрируйтесь, используя электронную почту и пароль
Опубликовать как гость
Электронная почта
Требуется, но не отображается
Опубликовать как гость
Электронная почта
Требуется, но не отображается
Как отменить свойство CSS?
Задавать вопрос
спросил
Изменено 5 лет, 1 месяц назад
Просмотрено 30 тысяч раз
К странице, над которой я работаю, прикреплено множество разных файлов CSS: файл boostrap. css, master.css и файл custom.css.
Я пытаюсь удалить свойство, так как не хочу, чтобы у ссылки в меню было свойство a:hover. Главный файл CSS имеет
#topSurround a:hover { цвет: #ffffff; }
CSS-файл начальной загрузки имеет
.nav > li > a:hover { текстовое оформление: нет; цвет фона: #eee; }
Я не хочу редактировать эти файлы, так как они являются основными файлами с используемым мной шаблоном и могут быть обновлены, поэтому я использую пользовательский файл CSS. Обычно я бы установил свойство по умолчанию, чтобы переопределить любое предыдущее использование свойства.
#topSurround a:наведите { цвет: нет; (не работает, так как это не правильное значение по умолчанию) }
Итак, два вопроса: какое значение по умолчанию для свойства цвета (похоже, его нет)? Есть ли более простой способ сделать это без перезаписи основных файлов?
4
Вы можете использовать цвет : наследуйте
, чтобы цвет использовал значение своих предков. цвет
необычен тем, что имеет разные значения по умолчанию в зависимости от контекста. Ссылка, например, обычно по умолчанию окрашена в синий цвет, а текст — в черный.
Если вам нужно переопределить существующий стиль, не используйте более конкретный селектор . Повышение специфичности означает, что вам просто нужно будет использовать больше селекторов в следующий раз, когда вы захотите его переопределить.
Вместо этого воспользуйтесь преимуществом каскада, используя селектор с такой же специфичностью и сделайте переопределение после исходного стиля:
/* старый стиль в какой-то библиотеке */ .foo .bar .baz { цвет синий; } ...в переопределяющем файле CSS... .foo .bar .baz { цвет: зеленый; }
2
Чтобы аннулировать собственность, вы можете использовать ключевое слово unset
.
Итак, в вашем пользовательском файле CSS вы можете сделать что-то вроде следующего: —
#topSurround a:hover { цвет: не установлен; }
Согласно веб-документам MDN: —
Неустановленное ключевое слово CSS сбрасывает свойство к его унаследованному значению, если оно наследуется от своего родителя, и к исходному значению
, если нет. Другими словами, он ведет себя как
наследует ключевое слово
в первом случае и аналогично начальному ключевому словуво втором случае. Его можно применить к любому свойству CSS, включая сокращение CSS all.
1
Лучше всего сделать более конкретное правило CSS , например:
body #topSurround a:hover { цвет: прозрачный; }
Специфичность — важная концепция CSS, как описано в этой статье:
http://coding.smashingmagazine.com/2007/07/27/css-specificity-things-you-should-know/
3
Я рекомендую попробовать:
#topSurround a:hover { цвет: наследовать; }
Что касается того, как перезаписать то, что добавляет Bootstrap, я думаю, что то, что вы делали, лучше всего.
Каждый стиль CSS имеет естественное значение по умолчанию. Просто не всегда нет
.