JavaScript的DOM_操作行内样式

一、检测浏览器是否支持css

  CSS 作为(X)HTML 的辅助,可以增强页面的显示效果。但不是每个浏览器都能支持最新的 CSS 能力。CSS 的能力和 DOM 级别密切相关,所以我们有必要检测当前浏览器支持CSS 能力的级别。

  DOM1 级实现了最基本的文档处理,DOM2 和 DOM3 在这个基础上增加了更多的交互能力,这里我们主要探讨 CSS,DOM2 增加了 CSS 编程访问方式和改变 CSS 样式信息。

  这种检测方案在 IE 浏览器上不精确,IE6 中,hasFeature()方法只为 HTML 和版本1.0 返回 true,其他所有功能均返回 false。但 IE 浏览器还是支持最常用的 CSS2 模块。

<script type="text/javascript">

    window.onload = function(){

        //检测浏览器是否支持 DOM1 级 CSS 能力或 DOM2 级 CSS 能力

        alert('DOM1 级 CSS 能力:' + document.implementation.hasFeature('CSS', '2.0'));

        alert('DOM2 级 CSS 能力:' + document.implementation.hasFeature('CSS2', '2.0'));

    }

</script>

 

 

 

 

二、获取和设置行内样式

  任何 HTML 元素标签都会有一个通用的属性:style。它会返回 CSSStypeDeclaration 对象。下面我们看几个最常见的行内 style 样式的访问方式。

  JavaScript的DOM_操作行内样式

  1、使用行内style获取行内样式

<script type="text/javascript">

    window.onload = function(){

        var box = document.getElementById('box'); //获取 box

        alert(box.style);//[object CSS2Properties]  CSS样式对象

        alert(box.style.color); //获取行内样式中的color属性的值

        alert(box.style.fontSize);//获取行内样式中的font-size属性的值,在这里如果属性有-这种符号有前缀后缀的需要将-去掉,后一个单词首字母大写

        alert(box.style.background);

        

        

        alert(box.style.float);    //获取行内样式中的float属性的值,但这种写法非IE不支持,要使用下面的写法

        alert(box.style.styleFloat);    //这种写法IE可以,其他不可以

        alert(box.style.cssFloat);    //获取行内样式中的float属性的值,但这种写法IE6,7,8不支持,要使用下面的写法做兼容

        alert(box.style.cssFloat || box.style.styleFloat);//跨浏览器兼容,谁有值就返回谁

        

    }

</script>

</head>

<body>

    <div id="box" style="color:#F00;background:#ccc; font-size:20px; float:right;">测试Div</div>

</body>

 

  2、使用行内style设置行内样式

<script type="text/javascript">

    window.onload = function(){

        var box = document.getElementById('box'); //获取 box

        box.style.color="red";

        box.style.fontSize="30px";

        box.style.background="#ccc";

        box.style.cssFloat = "right";//IE6,7,8没有用

        

        //做兼容:

        typeof box.style.cssFloat != 'undefined'? box.style.cssFloat='right':box.style.styleFloat='right';

    }

</script>

</head>

<body>

    <div id="box">测试Div</div>

</body>

 

 

 

 

三、DOM2 级样式规范为 style 定义了一些属性和方法。

  Firefox、Safari、Opera9+、Chrome 支持这些属性和方法。IE 6,7,8只支持 cssText,而getPropertyCSSValue()方法只有 Safari3+和 Chrome 支持。

<script type="text/javascript">

    window.onload = function(){

        var box = document.getElementById('box');     //获取 box

        alert(box.style.cssText);                     //获取 CSS 代码

        alert(box.style.length);                     //获取CSS属性的数量 IE6,7,8不支持

        //box.style.removeProperty('color');         //移除某个 CSS 属性,IE6,7,8 不支持

        box.style.setProperty('color','blue');         //设置某个 CSS 属性,IE6,7,8 不支持

    }

</script>

</head>

<body>

    <div id="box" style="color:#F00; font-size:20px;">测试Div</div>

</body>

   style 属性仅仅只能获取行内的 CSS 样式,对于另外两种形式内联<style>和链接<link>方式则无法获取到。

 

你可能感兴趣的:(JavaScript)