Перейти к содержимому

Как получить значение css свойства js

  • автор:

Как получить значение свойства css через javascript

Чтобы получить значения CSS свойств через JavaScript можно воспользоваться методом window.getComputedStyle() . Этот метод возвращает объект, содержащий значения всех CSS свойств элемента после применения всех таблиц стилей, а также значения свойств по умолчанию для данного элемента.

Так как метод возвращает обычный JavaScript объект, то далее мы можем обращаться к нужным нам свойствам (ключам) этого объекта.

Рассмотрим небольшой пример. В HTML документе находится параграф с каким-то текстом. Для параграфа заданы следующие стили:

p  color: red; text-align: center; font-weight: bold; font-size: 20px; word-spacing: 10px; > 

Переходим в JavaScript документ:

const el = document.querySelector('p'); // получаем наш параграф const styles = window.getComputedStyle(el); // получаем объект со всеми вычисленными стилями // Теперь можем обращаться к нужным нам CSS свойствам: console.log(styles.wordSpacing) // => 10px console.log(styles.textAlign) // => center console.log(styles.color) // => rgb(255, 0, 0) 

Как получать текущее CSS значение элемента

У меня есть элемент который будет изменять своё свойство scale динамически, и мне надо получать значение scale каждый раз, как оно изменяется, желательно без каких либо библиотек. Я знаю, что можно получить значение css свойства через getComputedStyle(), но если я не ошибаюсь оно получает его всего один раз, а мне надо, чтоб каждый раз, как значение изменялось.

Отслеживать
задан 9 янв 2021 в 12:21
11 1 1 бронзовый знак

А какую задачу это должно решить? И «динамически» — это какая-то бесконечная анимация или при изменении размера окна?

9 янв 2021 в 12:29

При скролле, элемент уменьшается и увеличивается, и при достижение определенного размера элемент должен пропадать

9 янв 2021 в 12:37

Если меняется при скролле, значит уже прикручен JS. Надо бы найти ту функцию, которая меняет scale, немного изменить, чтобы и меняла, и заодно проверяла новый размер. При необходимости — скрывала.

9 янв 2021 в 12:56

Если есть возможость, лучше менять свойство scale через js и соответственно там же менять переменную, а с неё уже брать значение.

Функция getComputedStyle

Функция getComputedStyle позволяет получить значение любого CSS свойства элемента, даже из CSS файла.

Синтаксис

let объект = getComputedStyle(элемент);

Подробности

Как оно работает (внимание: не так как мы ожидаем): параметром функция принимает элемент, а возвращает объект, который содержит в себе все CSS свойства переданного элемента. Давайте положим этот объект в переменную style . Название произвольное, это просто переменная — как придумаем, так и будем обращаться:

let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); // в style лежат CSS свойства

Давайте выведем, к примеру, ширину. Это делается так — style.width :

let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); console.log(style.width);

Чтобы вывести, к примеру, левый padding — делаем так — style.paddingLeft :

let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); console.log(style.paddingLeft);

В следующем примере мы выведем все интересующие нас CSS свойства для нашего элемента:

text

#elem < width: 200px; height: 200px; padding: 30px; border: 20px solid #BCBCBC; overflow: auto; >let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); console.log(‘paddingLeft: ‘ + style.paddingLeft); // выведет ’30px’ console.log(‘borderTopWidth: ‘ + style.borderTopWidth); // выведет ’20px’ console.log(‘borderTopStyle: ‘ + style.borderTopStyle); // выведет ‘solid’

Неточность getComputedStyle

Иногда функция getComputedStyle работает не совсем корректно с шириной и высотой. Это связано с тем, что padding и граница расширяют блок. В следующем примере блоку задана ширина 200px , а также граница и border . Реальная ширина блока 300px , но getComputedStyle все равно выведет 200px :

text

#elem < width: 200px; height: 200px; padding: 30px; border: 20px solid #BCBCBC; overflow: auto; >let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); console.log(‘width: ‘ + style.width); // выведет ‘200px’ console.log(‘height: ‘ + style.height); // выведет ‘200px’

То есть: получается, что getComputedStyle игнорирует расширение блока показывает его размеры так, как будто этого расширения не было. Но это еще не все: также имеет значение наличие или отсутствие полосы прокрутки — некоторые браузеры отнимают ширину полосы прокрутки от ширины, вычисленной через getComputedStyle , а некоторые не отнимают. В общем тут вообще все не кроссбраузерно и лучше getComputedStyle для определения ширины и высоты не использовать, а пользоваться метриками, которые мы изучим чуть ниже.

Вычисленные значения

Есть еще один нюанс: если ширина задана в % — то после работы getComputedStyle мы увидим ее в px . То есть по сути мы получаем не заданную ширину, а вычисленную. Смотрите на следующем примере:

text

#elem < width: 30%; /* ширина задана в % */ height: 200px; padding: 30px; border: 20px solid #BCBCBC; overflow: auto; >let elem = document.querySelector(‘#elem’); let style = getComputedStyle(elem); console.log(‘width: ‘ + style.width); // выведет ширину в px

Смотрите также

  • свойство cssText ,
    которое массово задает CSS стили

window.getComputedStyle()

Метод Window.getComputedStyle() возвращает объект, содержащий значения всех CSS-свойств элемента, полученных после применения всех активных таблиц стилей, и завершения базовых вычислений значений, которые они могут содержать. Некоторые CSS-свойства доступны через API, предоставляемые объектом, или индексацию по именам CSS-свойств.

Синтаксис

var style = window.getComputedStyle(element [, pseudoElt]);

Element , свойства которого необходимо получить.

Строка указывающая на найденный псевдо-элемент. Опускается (или null ) для не псевдо-элементов.

Возвращённый style живой CSSStyleDeclaration объект, который обновляется автоматически когда элемент стилей изменяется.

Выводы

Метод Window.getComputedStyle() предоставляет все значения CSS-свойств элементов после применения текущей таблицы стилей или базового расчёта каких-либо значений, которые могут быть.

Пример

var elem1 = document.getElementById("elemId"); var style = window.getComputedStyle(elem1, null); // this is equivalent: // var style = document.defaultView.getComputedStyle(elem1, null); 
style> #elem-container position: absolute; left: 100px; top: 200px; height: 100px; > /style> div id="elem-container">dummy/div> div id="output">/div> script> function getTheStyle() var elem = document.getElementById("elem-container"); var theCSSprop = window.getComputedStyle(elem,null).getPropertyValue("height"); document.getElementById("output").innerHTML = theCSSprop; > getTheStyle(); /script> 
function dumpComputedStyles(elem, prop)  var cs = window.getComputedStyle(elem, null); if (prop)  console.log(prop + " : " + cs.getPropertyValue(prop)); return; > var len = cs.length; for (var i = 0; i  len; i++)  var style = cs[i]; console.log(style + " : " + cs.getPropertyValue(style)); > > 

Описание

Возвращённый объект — это такой же объект, который возвращается из свойства элемента style (en-US); Так или иначе, эти два объекта имеют разные назначения. Объект который возвращается из getComputedStyle только для чтения и может быть использован для инспектирования стиля элемента (включая описание из элемента или внешней таблицы стилей). Объект element.style следует использовать для установки стилей на специфических элементах.

Первый аргумент должен быть элементом (вставка узлов которые не являются элементами, например #text выдаст ошибку).

defaultView

Во многих примерах кода, getComputedStyle используется из объекта document.defaultView . Почти во всех случаях это не нужно, поскольку getComputedStyle существует в объекте window . Это что-то на подобии шаблона defaultView который был некой прослойкой. Люди не хотели писать спецификацию для window и создавали API которое также могло использоваться для Java. Так или иначе есть только один случай когда метод defaultView должен использоваться: когда вы используете Firefox 3.6 чтобы получить доступ к вычисленным стилям.

Использования с псевдо-элементами

getComputedStyle может получить информацию о стилях из псевдо-элемента (например — ::after , ::before , ::marker , ::line-marker — спецификация).

style> h3::after  content: "rocks!"; > style> h3>generated contenth3> script> var h3 = document.querySelector("h3"); var result = getComputedStyle(h3, ":after").content; console.log("the generated content is: ", result); // возвратит 'rocks!' script> 

Notes

The values returned by getComputedStyle are known as resolved values . These are usually the same as the CSS 2.1 computed values , but for some older properties like width , height or padding , they are instead the used values . Originally, CSS 2.0 defined the computed values to be the «ready to be used» final values of properties after cascading and inheritance, but CSS 2.1 redefined computed values as pre-layout, and used values as post-layout. For CSS 2.0 properties, the getComputedStyle function returns the old meaning of computed values, now called used values. An example of difference between pre- and post-layout values includes the resolution of percentages that represent the width or the height of an element (also known as its layout), as those will be replaced by their pixel equivalent only in the used value case.

The returned value is, in certain known cases, expressly inaccurate by deliberate intent. In particular, to avoid the so called CSS History Leak security issue, browsers may expressly «lie» about the used value for a link and always return values as if a user has never visited the linked site. See http://blog.mozilla.com/security/2010/03/31/plugging-the-css-history-leak/ and http://hacks.mozilla.org/2010/03/privacy-related-changes-coming-to-css-vistited/ for details of the examples of how this is implemented. Most other modern browsers have applied similar changes to the application of pseudo-selector styles and the values returned by getComputedStyle .

During a CSS transition, getComputedStyle returns the original property value in Firefox, but the final property value in WebKit.

In Firefox, properties with the value auto return the used value, not the value auto . So if you apply top:auto; and bottom:0 ; on an element with height:30px and its containing block is height:100px; , upon requesting the computed style for top , Firefox will return top:70px , as 100px-30px=70px .

Спецификации

  • DOM Level 2 Style: getComputedStyle
  • CSS Object Model specification

Совместимость с браузерами

BCD tables only load in the browser

Смотреть также

  • window.getDefaultComputedStyle (en-US)
  • Resolved Value

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *