"Se um trabalhador quiser fazer bem o seu trabalho, ele deve primeiro afiar suas ferramentas." - Confúcio, "Os Analectos de Confúcio. Lu Linggong"
Primeira página > Programação > Como recuperar valores de propriedades CSS para elementos HTML em JavaScript?

Como recuperar valores de propriedades CSS para elementos HTML em JavaScript?

Publicado em 2024-11-06
Navegar:457

How to Retrieve CSS Property Values for HTML Elements in JavaScript?

Obter valores de propriedades CSS para elementos HTML em JavaScript

No desenvolvimento web, a manipulação dinâmica de propriedades CSS pode aprimorar a experiência do usuário e a interface. Com JavaScript, acessar essas propriedades é simples.

No seu cenário, um arquivo CSS está vinculado a uma página HTML e você precisa recuperar uma propriedade específica (por exemplo, cor) para um div com o nome de classe " disposição." Veja como fazer isso usando JavaScript:

Opção 1: análise de folhas de estilo de documento (não recomendado)

Explicação:
Este método envolve iterar manualmente pelo documento .styleSheets e analisando seu conteúdo para procurar a propriedade desejada. No entanto, essa abordagem não é recomendada, pois pode se tornar complicada, especialmente para arquivos CSS complexos ou quando você precisa recuperar propriedades de vários elementos.

Opção 2: emular elemento e usar estilo computado (preferencial)

Explicação:
Este método é mais eficiente e fornece resultados precisos. Envolve a criação de um elemento com o mesmo nome de classe do elemento de destino e, em seguida, o acesso ao estilo computado do elemento criado. O estilo calculado representa o estilo real aplicado ao elemento, incluindo estilos herdados e quaisquer modificações feitas por meio de folhas de estilo do usuário ou JavaScript.

Código JavaScript:

function getStyleProp(elem, prop) {
  if (window.getComputedStyle) {
    return window.getComputedStyle(elem, null).getPropertyValue(prop);
  } else if (elem.currentStyle) {
    return elem.currentStyle[prop]; // IE compatibility
  }
}
window.onload = function () {
  var d = document.createElement("div"); // Create a div element
  d.className = "layout"; // Set the class name
  alert(getStyleProp(d, "color")); // Retrieve the "color" property
};

Considerações sobre estilo não inline

Se desejar recuperar propriedades de estilo herdadas sem definições de estilo inline, você pode remover temporariamente os estilos inline e depois recuperar os valores herdados.

Código JavaScript:

function getNonInlineStyle(elem, prop) {
  var style = elem.cssText; // Cache the inline style
  elem.cssText = ""; // Remove inline styles
  var inheritedPropValue = getStyleProp(elem, prop); // Retrieve inherited value
  elem.cssText = style; // Restore inline style
  return inheritedPropValue;
}
Declaração de lançamento Este artigo foi reimpresso em: 1729674691 Se houver alguma violação, entre em contato com [email protected] para excluí-lo
Tutorial mais recente Mais>

Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.

Copyright© 2022 湘ICP备2022001581号-3