DOM操作
JS中的DOM操作主要可以改变网页中的内容,结构(标签),属性以及样式.
同样这些操作针对于DOM而言也是通过操作对象的属性来实现的
改变元素中的内容
- 对于文本框元素而言,其内容属于value属性的值
- 对于其它标签内容指的是写在两个标签之间的内容部分,所以无法使用value属性实现
为了解决这个问题我们使用两个节点对象属性
- 元素的innerText属性
- 元素的innerHTML属性
这两个属性都可以修改一个节点之间的内容
注意:
对于HTML文件而言能够识别<>
,如果内容里面有<>
,则对于HTML文件而言可能会将这个内容字符串里面的<>
当成标签处理
两者之间的区别
innerText
- innerText在获取内容操作时,不会将内部的标签进行字符串处理,不会获取标签
- innerText在设置内容时,会将字符串直接输出到页面不会解析内容中的
<>
,并且会保留字符串内的空格以及换行.
innerHTML
- innerHTML在获取内容操作时,会将其内部的所有标签及内容全部进行字符串处理并返回
- innerHTML在设置内容时,会将字符串里面的"<>"进行解析然后再体现到页面中,不会保留字符串内的空格及换行。
实例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>DOM操作之改变文本内容</title>
<style>
</style>
</head>
<body>
<input type="text" value="请输入一个内容" id="txt">
<h3 id="myh3"><u>改变之前的内容1</u></h3>
<h2 id="myh2"><u>改变之前的内容2</u></h2>
<b id="myb">a</b>
<script>
window.onload = function () {
var txt = document.getElementById("txt");
txt.onmousedown = function () {
txt.value = "改变之后";
}
var h3 = document.querySelector("#myh3");
h3.onmousedown = function () {
h3.innerText = "改变之后1";
}
var h2 = document.querySelector("#myh2");
h2.onmousedown = function () {
h2.innerHTML = "改变之后2";
}
var b = document.getElementById("myb");
b.onmousedown = function () {
b.innerHTML = "<u>这是下划线</u>";
}
}
</script>
</body>
</html>
改变元素的样式
可以用DOM操作获取到元素对象之后,同时可以使用JS对元素的样式(大小,颜色,位置等)进行操作
常用方式
- element.style开始对style(样式)的内容进行操作
- element.className通过对类名进行样式操作
通过style属性操作样式
- 元素对象的style属性也是一个对象
- 通过对元素的style进行样式属性=值
- JS里面样式命名方式采取的是驼峰命名法
- JS修改style样式操作,产生的是行内样式,CSS权重较高
通过操作className属性
- 元素对象.className=值,使用className并非class,因为JS里面的class是特殊关键字
- 如果样式修改的比较多,利用这样方式修改更为方便
- className会直接更改元素的class属性的内容,会覆盖原始的class值,如果不想覆盖的话使用多类名即可
实例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>鼠标移入表格一行换色</title>
<style>
* {
margin: 0px;
padding: 0px;
}
table tr td {
border: 1px solid red;
text-align: center;
}
table {
margin: 100px auto;
width: 400px;
height: 400px;
border-collapse: collapse;
}
</style>
</head>
<body>
<table>
<tr>
<td>
红米
</td>
<td>
5900元
</td>
</tr>
<tr>
<td>
华为
</td>
<td>
9999元
</td>
</tr>
<tr>
<td>
小米
</td>
<td>
2000元
</td>
</tr>
<tr>
<td>
vivo
</td>
<td>
100元
</td>
</tr>
</table>
<script>
window.onload = function () {
var a = document.querySelectorAll("table tr")
for (var i = 0; i < a.length; i++) {
a[i].onmouseover = function () {
for (var j = 0; j < a.length; j++) {
a[j].style.backgroundColor = "white";
}
this.style.backgroundColor = "orange";
}
a[i].onmouseout = function () {
for (var j = 0; j < a.length; j++) {
a[j].style.backgroundColor = "white";
}
b.style.display = "none";
}
}
}
</script>
</body>
</html>