zoukankan      html  css  js  c++  java
  • javascript 获取元素样式的方法

    javascript 获取元素样式常用方法。
    Javascript获取CSS属性值方法:getComputedStyle和currentStyle 
    1 .对于元素的内联CSS样式(<div style="color:#369">hello</div>),可以直接使用element.style.color来直接获取css属性的值; 
    2. 但是对于外部定义的css样式使用这种方式就无法获取了,而且IE浏览器和其他标准浏览器(Firefox,Chrome,Opera,Safari)使用的方法不一样,IE浏览器使用element.currentStyle,W3C标准浏览器使用getComputedStyle来获取。 
    1. IE获取元素外部定义的CSS属性值: element.currentStyle 
    currentStyle对象返回了元素上的样式表,但是style对象只返回通过style标签属性应用到元素的内嵌样式。 
    因此,通过currentStyle对象获取的样式值可能与通过style对象获取的样式值不同。 
    例如,如果段落的color属性值通过链接或嵌入样式表设置为红色( red ),而不是内嵌的话,对象.currentStyle.color 将返回正确的颜色,而对象style.color不能返回值。但是,如果用户指定了 <P STYLE="color:'red'">,currentStyle和STYLE对象都将返回值 red。 
    currentStyle对象反映了样式表中的样式优先顺序。

    在 HTML 中此顺序为: 

    1) 内嵌样式 
    2) 样式表规则 
    3) HTML 标签属性 
    4) HTML 标签的内部定义 
    2. W3C获取元素外部定义的CSS属性值: window.getComputedStyle(element, pseudoElt) 
    element必选,HTML元素 
    pseudoElt必选,获取该元素的伪类样式 
    function getStyle(node, property){ 
    if (node.style[property]) { 
    return node.style[property]; 

    else if (node.currentStyle) { 
    return node.currentStyle[property]; 
    // www.jbxue.com
    else if (document.defaultView && document.defaultView.getComputedStyle) { 
    var style = document.defaultView.getComputedStyle(node, null); 
    return style.getPropertyValue(property); 

    return null
  • 相关阅读:
    LintCode 82. 落单的数
    LintCode 373. 奇偶分割数组
    LintCode 2. 尾部的零
    LintCode 413. 反转整数
    LintCode 13. Implement strStr()
    串匹配
    【剑指offer】面试题 57. 和为 S 的数字
    二分查找
    整除个数
    使用Eclipse创建Web Services
  • 原文地址:https://www.cnblogs.com/linuxnotes/p/3707870.html
Copyright © 2011-2022 走看看