- Работа с CSS через Javascript
- Получение всех CSS-свойств элемента ( метод window.getComputedStyle() )
- Синтаксис метода window.getComputedStyle() :
- Использование метода window.getComputedStyle() с псевдоэлементами
- Управление встроенными стилями элемента
- Особенности именования свойств объекта CSSStyleDeclaration:
- Особенности использования свойств объекта CSSStyleDeclaration:
- You might also like.
- How to get CSS values in JavaScript
- Getting inline styles
- Getting computed styles
- Getting styles from pseudo elements
- Wrapping up
Работа с CSS через Javascript
Получение всех CSS-свойств элемента ( метод window.getComputedStyle() )
Метод window.getComputedStyle() возвращает объект, содержащий значения всех CSS-свойств элемента после применения всех активных таблиц стилей и завершения базовых вычислений значений, которые они могут содержать.
Синтаксис метода window.getComputedStyle() :
- element — элемент (Element), CSS-свойства которого необходимо получить (вставка узлов, которые не являются элементами, например, #text , выдаст ошибку);
- pseudoElt (необязательный) — строка указывающая на найденный псевдоэлемент (опускается или null — для не псевдоэлементов).
Возвращённый объект style — «живой» объект CSSStyleDeclaration, который обновляется автоматически при изменении стилей элемента, только для чтения и может быть использован для инспектирования стиля элемента (включая описание из элемента или внешней таблицы стилей).
ВАЖНО! Для использования метода window.getComputedStyle() для какого-либо элемента необходимо дождаться загрузки этого элемента (страницы) (используйте window.load или расположите скрипт ниже необходимого элемента).
Использование метода window.getComputedStyle() с псевдоэлементами
Метод getComputedStyle() может получить информацию о стилях из псевдоэлемента (например, ::after , ::before , ::marker , ::line-marker и т.д.):
Управление встроенными стилями элемента
Самый простой способ управления стилями CSS с помощью JS — это манипулирование атрибутом style отдельных элементов документа (подробнее об атрибуте элемента и свойстве элемента). При этом свойство style объекта Element имеет одну отличительную особенность: его значением является не строка, а объект CSSStyleDeclaration. Свойства этого объекта представляют CSS-свойства, определенные в HTML-атрибуте style.
Для нестандартных атрибутов DOM свойство узла как объекта DOM не создаётся.
h3 . style . fontWeight = «bold» ; // свойство, соответствующее атрибуту с дефисом, — через CamelCase
Свойства стиля объекта CSSStyleDeclaration имеют тип всех значений string .
Кроме того, во всех свойствах позиционирования должны быть указаны единицы измерения, например:
Особенности именования свойств объекта CSSStyleDeclaration:
- Если имя CSS-атрибута содержит дефисы (например, font-size ), имя свойства объекта CSSStyleDeclaration образуется путем удаления дефисов и использования записи формата CamelCase (например, CSS-атрибут border-left-width доступен через свойство borderLeftWidth ).
- Если CSS-свойство имеет имя, совпадающее с зарезервированным словом языка JavaScript (например, float ), к этому имени добавляется префикс «css». В результате получим свойство cssFloat объекта CSSStyleDeclaration.
Особенности использования свойств объекта CSSStyleDeclaration:
- Атрибут< style>HTML-элемента — это его встроенный стиль, который в целом удобно использовать для начальной установки значений стиля. Однако сценарии JS могут читать свойства объекта CSSStyleDeclaration, только если эти свойства были ранее установлены сценарием на языке JavaScript или если HTML-элемент имеет встроенный атрибут style , установивший нужные свойства, например:
console . log ( h3 . style . position ) ; // пустая строка, свойство не установлено сценарием JS или атрибутом style
Чтение встроенного стиля элемента представляет особую сложность, когда выполняется чтение свойств стиля, имеющих единицы измерения, а также свойств сокращенной формы записи (сценарий должен включать реализацию синтаксического анализа строк с CSS-стилями, чтобы обеспечить возможность извлечения и дальнейшего использования значений). Иногда бывает проще прочитать или записать единственную строку во встроенный стиль элемента, чем обращаться к объекту CSSStyleDeclaration . Для этого можно использовать методы getAttribute() и setAttribute() объекта Element или свойство cssText объекта CSSStyleDeclaration (подробнее. ).
Добавление элементам классов, атрибутов и CSS-стилей (их удаление и проверка наличия)
Как правило, существует два способа задания стилей для элемента:
- cоздать класс в CSS и в HTML как и использовать его;
- определять стили непосредственно в атрибуте style как .
JavaScript может менять и классы, и свойство style , однако определение и изменение классов – предпочтительный вариант по сравнению с изменением style .
Использование style является приемлемым, если мы вычисляем координаты элемента и хотим установить их из JavaScript, например:
How to get CSS styles from an element with JavaScript
In JavaScript, sometimes, you might want to retrieve CSS styles applied to an element through inline styles or external style sheets. There are multiple ways to do this, depending on whether you fetch inline styles or rendered styles.
In vanilla JavaScript, the DOM style property is used to get the styles applied to an HTML element using the style attribute. Let us say we have the following HTML element:
button id="clickMe" style="color: red; font-weight: bold;">Click Mebutton>
const btn = document.getElementById('clickMe') // pint color & font weight properties console.log(btn.style.color) // red console.log(btn.style.fontWeight) // bold
However, the style property only works for the inline styles defined using the style attribute. If you try to access a property not defined as an inline style rule, let us say the backgroundColor , a null value will be returned:
console.log(btn.style.backgroundColor) // null
The style property can not be used to retrieve style information from elsewhere, such as the style rules defined using the
To get the actual CSS property values used to render an HTML element, you can use the getComputedStyle() method. This method works for everything: inline styles, external style sheets, and browser defaults. Let us say you have the following embedded
style> button background-color: yellow; text-align: center; height: 20px; width: 100px; > style>
The getComputedStyle() method is always called on the window object with the element as a parameter and returns an object of properties:
const btn = document.getElementById('clickMe') // get all rendered styles const styles = window.getComputedStyle(btn)
Now you can access any CSS property like you’d have done with the style property. For example, to access the background-color , you can do the following:
const backgroundColor = styles.backgroundColor // rgb(255, 255, 0)
To get the rendered height and width of the element regardless of whether or not it was defined, use the following code:
const height = styles.height // 20px const width = styles.width // 100px
Alternatively, you can use the getPropertyValue() method on the styles object to access a CSS property. It accepts the actual name of the CSS property and not the one used for JavaScript:
const fontWeight = styles.getPropertyValue('font-weight') // 700
Note: The value 700 is equivalent to bold for the CSS property font-weight . Similarly, rgb(255, 255, 0) is just an RGB value which is the same as yellow .
The getComputedStyle() method is used to get the actual CSS properties used by the browser to render the element. It works in all modern and old browsers, including IE 9 and higher. Finally, the getComputedStyle() method only works for getting styles. You can not use it to set a specific style to an HTML element. To set CSS properties, you should always use the DOM style property, as explained in an earlier article.
CSS pseudo-elements are extremely useful to style parts of an element without additional HTML elements. To get style information from pseudo-elements, you pass in the name of the pseudo-element as a second argument to the getComputedStyle() method. Let us say we have the following
element:
p class="tip">Learn JavaScrit for free!p>
.tip::first-letter color: green; font-size: 22px; >
To retrieve the color property of the .tip::first-letter , you should use the following JavaScript code snippet:
const tip = document.querySelector('.tip') // retrieve all styles const styles = window.getComputedStyle(tip, '::first-letter') // get color console.log(styles.color) // rgb(0, 128, 0)
- The DOM style property to retrieve inline styles applied to an element using the style attribute.
- The window.getComputedStyle() method to retrieve computed styles applied to an element through elements and external style sheets. To get pseudo-elements CSS styles, you need to pass the name of the pseudo-element as a second parameter.
✌️ Like this article? Follow me on Twitter and LinkedIn. You can also subscribe to RSS Feed.
You might also like.
How to get CSS values in JavaScript
CSS alone is not enough sometimes. You might need to control your CSS values with JavaScript. But how do you get CSS values in JavaScript?
Turns out, there are two possible ways, depending on whether you’re trying to get inline styles or computed styles.
Getting inline styles
Inline styles are styles that are present in the HTML in the style attribute.
div class="element" style="font-size: 2em; color: red;"> Red hot chili pepper! div>
To get inline styles, you can use the style property.
const element = document.querySelector('.element') const fontSize = element.style.fontSize console.log(fontSize) // 2em const color = element.style.color console.log(color) // red
Getting computed styles
If your styles are written in the CSS file, you need to get the computed style. To do so, you can use getComputedStyle .
const style = getComputedStyle(Element, pseudoElement)
Element here refers to the element you’ve selected with querySelector .
pseudoElement here refers to the string of the pseudo element you’re trying to get (if any). You can omit this value if you’re not selecting a pseudo element.
Let’s walk through an example to help make sense of things. Say you have the following HTML and CSS:
div class="element">This is my elementdiv>
.element background-color: red; >
First, you need to select the element with querySelector . Then, you use getComputedStyle to get the element’s styles.
const element = document.querySelector('.element') const style = getComputedStyle(element)
If you log style , you should see an object that contains every CSS property and their respective values.
You can also see this object in Chrome’s and Firefox’s dev tools.
For Firefox dev tools, look under “Inspector”, “Computed”.
For Chrome dev tools, look under “Elements”. If the dev tools window is large, you can see the computed styles on the right panel. If the dev tools window is small, you can look under the “Computed” tab.
To get the value of a CSS property, you write the property in camel case.
const style = getComputedStyle(element) const backgroundColor = style.backgroundColor console.log(backgroundColor) // rgb(0, 0, 0)
Note: getComputedStyle is read-only. You cannot set a CSS value with getComputedStyle .
Note2: getComputedStyle gets the computed CSS values. You’ll get px from getComputedStyle , not relative units like em and rem .
Getting styles from pseudo elements
To get styles from pseudo elements, you need to pass in a string of the pseudo element as the second argument to getComputedStyle .
div class="element">This is my elementdiv>
.element background-color: red; > .element::before content: 'Before pseudo element'; >
const element = document.querySelector('.element') pseudoElementStyle = getComputedStyle(element, '::before') console.log(pseudoElementStyle.content) // Before pseudo element
Wrapping up
You can get CSS values in JavaScript through two methods:
The style property only retrieves inlined CSS values while getComputedStyle style retrieves computed CSS values.
If this lesson has helped you, might enjoy Learn JavaScript, where you’ll learn how to build anything you want from scratch. Enrollment for Learn JavaScript opens in July 2018 (next week!).
I hope you found this useful. If you did, I hope you’ll share it with someone else. And feel free to reach out if you have any questions or comments.
Thanks for reading, all the best, and happy coding!