使用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")
1、首先来看下测试代码,html里,主要部分有二个input输入框,和一个按钮。
2、在js代码里,借助Jquery插件库来操作,以减少代码,所以先引入对应的脚本库文件。
3、js代码里,为按钮添加点击事件,点击后,就用jquery设置姓名输入框的disabled属性,设置为false,这样输入框就不能输入了,为禁止状态了。只要调用jquery的 attr方法,然后输入属性的名称和值就行了:$("#name").attr('disabled', true)。
4、运行页面,可以看到现在的输入框是可以输入的,是正常状态的,点击一下“修改”按钮。
5、点击后,输入框就变成了禁止状态了,成功设置了输入框的属性。