js怎么设置css样式?
1、直接设置style对象(内联样式)
使⽤JavaScript设置元素样式的最简单⽅法是使⽤style属性。在我们通过JavaScript访问的每个HTML元素时都有⼀个 style对象。此对象允许我们指定CSS属性并设置其值。例如,这是设置id 值为demo的HTML元素的字体颜⾊、背景颜⾊、的样式:
var myElement = document.querySelector("#demo");
// 把颜⾊设置成紫⾊
lor = 'purple';
// 将背景颜⾊设置为浅灰⾊
elem.style.backgroundColor = '#e5e5e5';
// 将⾼度设置为150 px
elem.style.height = '150px';
注:JavaScript使⽤驼峰原则(例:backgroundColor)⽽不是短划线(background-color)表⽰属性名称
该style属性在元素上添加样式内联:
<div id="demo" >
Hello, world!
</div>
但是,这可能会使我们的标记变得⾮常混乱。浏览器渲染的性能也较差。
2、设置style属性--添加全局样式
另⼀种⽅法是将<style></style>⾥带有CSS属性的元素注⼊DOM。将在设置应⽤于⼀组元素⽽不仅仅是⼀个元素的样式时,这⾮常有⽤。
⾸先,我们将创建⼀个样式元素。
var style = ateElement('style');
接下来,我们将通过innerHTML来给<style>添加我们的样式。
var style = ateElement('style');
style.innerHTML =
'.some-element {' +
'color: purple;' +
'background-color: #e5e5e5;' +
'height: 150px;' +
'}';
最后,我们将把样式注⼊DOM。为此,我们将获取script我们在DOM中到的第⼀个标记,并⽤它insertBefore()来添加我们的style标记。
// 创建我们的样式表
var style = ateElement('style');
style.innerHTML =
'.some-element {' +
'color: purple;' +
'background-color: #e5e5e5;' +
'height: 150px;' +
'}';
// 获取第⼀个脚本标记
var ref = document.querySelector('script');cssclass属性
// 在第⼀个脚本标签之前插⼊新样式
ref.parentNode.insertBefore(style, ref);
3、使⽤JavaScript添加和删除类:add()和remove()
这种⽅法涉及添加和删除类值,这反过来⼜会改变应⽤的样式规则。例如,假设我们有⼀个样式规则,如下所⽰:
.disableMenu {
display: none;
}
在HTML中,您有⼀个id为 dropDown的菜单:
<ul id="dropDown">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</ul>
现在,如果我们想将.disableMenu 样式规则应⽤于此元素中,我们需要做的就是将disableMenu作为类值添加到dropDown元素:<ul class="disableMenu" id="dropDown">
<li>One</li>
<li>Two</li>
<li>Three</li>
<li>Four</li>
<li>Five</li>
<li>Six</li>
</ul>
要使⽤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");
ve("disableMenu");

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。