>  기사  >  웹 프론트엔드  >  DOM에서 속성, 클래스 및 스타일을 수정하는 방법

DOM에서 속성, 클래스 및 스타일을 수정하는 방법

清浅
清浅원래의
2019-01-16 13:32:086091검색


通过jQuery来获取要修改的DOM元素,然后通过JavaScript中方法来对属性、类以及样式进行修改

今天在本篇文章中将分享的是如何通过修改html元素节点的样式,类和属性来进一步的更改dom,,具有一定的参考价值,希望对大家有所帮助。

DOM에서 속성, 클래스 및 스타일을 수정하는 방법

【推荐课程:JavaScript教程jQuery教程

查找要选择的元素

我们可以通过jQuery来选择和修改DOM中的元素。jQuery简化了选择一个或多个元素并同时对所有元素应用更改的过程

其中,document.querySelector()和document.getElementById()是用于访问单个元素的方法。

例:

function myFunction() {
    document.querySelector(".example").style.backgroundColor = "pink";
}

效果图:

DOM에서 속성, 클래스 및 스타일을 수정하는 방법

访问单个元素,我们可以改变文本的内容

 document.querySelector(".example").textContent="点击文本发生变化";

效果图:

修改属性

属性是包含有关HTML元素的其他信息的值。它们通常由名称/值构成,具体取决于元素。

在JavaScript中,我们有四种修改元素属性的方法:

方法
描述

hasAttribute()  返回一个true或false布尔值  element.hasAttribute('href');   
getAttribute() 返回指定属性的值或 null element.getAttribute('href');   
setAttribute()  添加或更新指定属性的值 element.setAttribute('href', 'index.html');
removeAttribute()  从元素中删除属性   element.removeAttribute('href');    
function demo(){
	var img =document.getElementsByTagName("img")[0];
	img.setAttribute('src', 'images/2.jpg');
}

效果图:

DOM에서 속성, 클래스 및 스타일을 수정하는 방법

修改类

CSS类用于将样式应用于多个元素,这与每页只能存在一次的ID不同。在JavaScript中,我们有className和classList属性来处理class属性。

方法/属性
描述

className 获取或设置类值 element.className;    
classList.add()   添加一个或多个类值 element.classList.add('active');    
classList.toggle()    在元素中切换类名 element.classList.toggle('active');
classList.contains()     检查类值是否存在  element.classList.contains('active');    
classList.replace()   用新的类值替换现有的类值 element.classList.replace('old', 'new');
classList.remove()  删除类值 element.classList.remove('active');    

例:

.demo1{
			width:100px;
			height:100px;
			background-color: pink;
		}
		.demo2{
			width:200px;
			height:200px;
			background-color:skyblue;
		}
function demo(){
	var p =document.getElementsByTagName("p")[0];
	p.classList.toggle("demo2");
}

效果图:

Image 10.jpg

总结:以上就是本篇文章的全部内容了,希望对大家有所帮助。


위 내용은 DOM에서 속성, 클래스 및 스타일을 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.