js操作style属性的路径问题

JavaScript017

js操作style属性的路径问题,第1张

1、直接设置style对象(内联样式)

使用JavaScript设置元素样式的最简单方法是使用style属性。在我们通过JavaScript访问的每个HTML元素时都有一个 style对象。此对象允许我们指定CSS属性并设置其值。例如,这是设置id 值为demo的HTML元素的字体颜色、背景颜色、的样式:var myElement = document.querySelector("#demo")

// 把颜色设置成紫色

elem.style.color = 'purple'

// 将背景颜色设置为浅灰色

elem.style.backgroundColor = '#e5e5e5'

// 将高度设置为150 px

elem.style.height = '150px'

注:JavaScript使用驼峰原则(例:backgroundColor)而不是短划线(background-color)表示属性名称

该style属性在元素上添加样式内联:

Hello, world!

但是,这可能会使我们的标记变得非常混乱。浏览器渲染的性能也较差。

2、设置style属性--添加全局样式

另一种方法是将里带有CSS属性的元素注入DOM。将在设置应用于一组元素而不仅仅是一个元素的样式时,这非常有用。

首先,我们将创建一个样式元素。var style = document.createElement('style')

接下来,我们将通过innerHTML来给

style.innerHTML =

'.some-element {' +

'color: purple' +

'background-color: #e5e5e5' +

'height: 150px' +

'}'

最后,我们将把样式注入DOM。为此,我们将获取script我们在DOM中找到的第一个标记,并用它insertBefore()来添加我们的style标记。// 创建我们的样式表

var style = document.createElement('style')

style.innerHTML =

'.some-element {' +

'color: purple' +

'background-color: #e5e5e5' +

'height: 150px' +

'}'

// 获取第一个脚本标记

var ref = document.querySelector('script')

// 在第一个脚本标签之前插入新样式

ref.parentNode.insertBefore(style, ref)

3、使用JavaScript添加和删除类:add()和remove()

这种方法涉及添加和删除类值,这反过来又会改变应用的样式规则。例如,假设我们有一个样式规则,如下所示:.disableMenu {

display: none

}

在HTML中,您有一个id为 dropDown的菜单:

123456

现在,如果我们想将.disableMenu 样式规则应用于此元素中,我们需要做的就是将disableMenu作为类值添加到dropDown元素:

OneTwoThreeFourFiveSix

要使用JavaScript完成相同的结果,我们将使用classList API。此API使得从HTML元素添加或删除类值变得非常简单。

要将disableMenu类名添加到我们的dropDown元素,请在HTML元素的classList属性上使用add()方法:var theDropDown = document.querySelector("#dropDown")

theDropDown.classList.add("disableMenu")

要删除disableMenu类名,我们可以调用classList API的remove()方法:var theDropDown = document.querySelector("#dropDown")

theDropDown.classList.remove("disableMenu")

是这样的,一开始需要获取某一个元素的 left 值,我就用 ele.style.left 去获取了(基础不扎实还好意思来丢人),然后居然返回的是空。

好吧,追本溯源,问题的根源以及区别就在这里了。

所以,我那样是获取不到某一个元素的一个其他方式设置的样式属性值的,所以我就打算谷歌一下别的方法了。

特点:

- 只可读,但是可以读取所有的样式属性值。但是不能通过该方法去设置样式属性值。

currentStyle 获取的是一个元素的所有的样式属性值,这一点功能是与 getComputedStyle() 一样的,但是在获取某一个具体的属性的时候,可以结合 getAttribute 来实现。

和 getComputedStyle 方法不同的是,currentStyle 要获得属性名的话必须采用驼峰式的写法。也就是如果我需要获取 font-size 属性,那么传入的参数应该是 fontSize。因此在IE 中要获得单个属性的值,就必须将属性名转为驼峰形式。 ( 感谢这篇文章。 )

关于 getComputedStyle 返回的值,具体查看这里。

不管你最初定义的样式是什么,涉及到宽度高度之类的,返回的都是最后实际使用的宽度和高度。

关于 ele.style 的返回值,是和定义的样式的值相等的,如果设置为auto,就直接返回auto。

然后是元素的高宽,对于一个没有设定高宽的元素而言,在 IE678 下使用 getPropertyValue("width|height") 得到的是 auto 。而标准浏览器会直接返回它的 px 值,当然我们希望在 IE 下也返回 px 值。

这里的 HACK 方法是使用 element.getBoundingClientRect() 方法。

element.getBoundingClientRect() -- 可以获得元素四个点相对于文档视图左上角的值 top、left、bottom、right ,通过计算就可以容易地获得准确的元素大小。

参考链接 chokcoco的博客园

通过节点的style属性添加

1、定义一个节点

<div id='tsdiv'></div>

2、获取div节点

var domdiv = document.getElementById('tsdiv')//通过document.getElementById获取dom节点

3、添加style

div.style.display = 'none'//添加style属性,设置display样式为none