DOM_概述
-
概念: Document Object Model 文档对象模型
-
将标记语言文档的各个组成部分,封装为对象。可以使用这些对象,对标记语言文档进行CRUD的动态操作
-
-
W3C DOM 标准被分为 3 个不同的部分:
-
核心 DOM - 针对任何结构化文档的标准模型
-
Node:节点对象,其他5个的父对象
-
Document:文档对象
-
Element:元素对象
-
Attribute:属性对象
-
Text:文本对象
-
Comment:注释对象
-
-
-
XML DOM - 针对 XML 文档的标准模型
-
HTML DOM - 针对 HTML 文档的标准模型
-
DOM_Document对象_获取Element方法
-
核心DOM模型:Document:文档对象
-
创建:在html dom模型中可以使用window对象来获取
-
window.document
-
-
-
获取Element对象常用方法
getElementById() | 根据id属性值获取元素对象。id属性值一般唯一 |
getElementsByTagName() | 根据元素名称获取元素对象们。返回值是一个数组 |
getElementsByClassName() | 根据Class属性值获取元素对象们。返回值是一个数组 |
getElementsByName() | 根据name属性值获取元素对象们。返回值是一个数组 |
- 示例代码
<script type="text/javascript">
var elements1 = document.getElementsByClassName("cl1");
document.write(elements1.length + "<br/>");
var elements2 = document.getElementsByTagName("div");
document.write(elements2.length + "<br/>");
var elements3 = document.getElementsByName("gender");
document.write(elements3.length + "<br/>");
</script>
DOM_Document对象_创建DOM对象
创建其他对象方法
-
createAttribute(name)
-
createComment()
-
createElement()
-
createTextNode()
DOM_Element对象
-
获取/创建:通过document来获取和创建
-
常用方法
-
removeAttribute():删除属性
-
setAttribute():设置属性
-
-
示例代码
<body>
<a>打我呀!!</a>
<input id="btn_set" type="button" value="设置属性">
<input id="btn_remove" type="button" value="删除属性">
<script type="text/javascript">
var a = document.getElementsByTagName("a")[0];
//设置属性
var btn_set = document.getElementById("btn_set");
btn_set.onclick = function () {
a.setAttribute("href","https://www.baidu.com");
}
//删除属性
var btn_remove = document.getElementById("btn_remove");
btn_remove.onclick = function () {
a.removeAttribute("href");
}
</script>
</body>
DOM_Node对象
-
概念:节点对象,其他5个的父对象,所有dom对象都可以被认为是一个节点
-
常用方法
-
appendChild():向节点的子节点列表的结尾添加新的子节点。
-
removeChild():删除(并返回)当前节点的指定子节点。
-
replaceChild():用新节点替换一个子节点。
-
-
属性:parentNode 返回节点的父节点
-
示例代码
<style>
div{
border: 1px solid red;
}
#div1{
width: 200px;
height: 200px;
}
#div2{
width: 100px;
height: 100px;
}
</style>
<body>
<div id="div1">
<div id="div2">div2</div>
div1
</div>
<a href="javascript:void(0)" id="del">删除子节点</a>
<a href="javascript:void(0)" id="add">增加子节点</a>
<script type="text/javascript">
//删除子节点
var del = document.getElementById("del");
del.onclick = function () {
var div1 = document.getElementById("div1");
var div2 = document.getElementById("div2");
div1.removeChild(div2);
}
//增加子节点
var add = document.getElementById("add");
add.onclick = function () {
var div1 = document.getElementById("div1");
var div2 = document.createElement("div")
div2.setAttribute("id","div2");
div1.appendChild(div2);
}
</script>
案例4-动态表格
- 实现代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态表格</title>
<style>
table{
border: 1px solid;
margin: auto;
width: 500px;
}
td,th{
text-align: center;
border: 1px solid;
}
div{
text-align: center;
margin: 50px;
}
</style>
</head>
<body>
<div>
<input type="text" id="id" placeholder="请输入编号">
<input type="text" id="name" placeholder="请输入姓名">
<input type="text" id="gender" placeholder="请输入性别">
<input type="button" value="添加" id="btn_add">
</div>
<table id="table">
<caption>学生信息表</caption>
<tr>
<th>编号</th>
<th>姓名</th>
<th>性别</th>
<th>操作</th>
</tr>
<tr>
<td>1</td>
<td>令狐冲</td>
<td>男</td>
<td><a href="">删除</a></td>
</tr>
<tr>
<td>2</td>
<td>任我行</td>
<td>男</td>
<td><a href="">删除</a></td>
</tr>
<tr>
<td>3</td>
<td>岳不群</td>
<td>?</td>
<td><a href="">删除</a></td>
</tr>
</table>
<script>
//获取btn
var btn_add = document.getElementById("btn_add");
//绑定事件
btn_add.onclick = function () {
//获取每个输入框中的内容
var id = document.getElementById("id").value;
var name = document.getElementById("name").value;
var gender = document.getElementById("gender").value;
//获取表格
var table = document.getElementById("table");
table.innerHTML += "<td>"+ id +"</td>" +
"<td>"+ name +"</td>" +
"<td>"+ gender +"</td>" +
"<td><a href='javascript:void(0);' onclick='delTr(this);'>删除</a></td>";
/* //创建tr
var tr = document.createElement("tr");
//创建td id格子
var td_id = document.createElement("td");
var text_id = document.createTextNode(id);
td_id.appendChild(text_id);
tr.appendChild(td_id);
//创建 name 格子
var td_name = document.createElement("td");
var text_name = document.createTextNode(name);
td_name.appendChild(text_name);
tr.appendChild(td_name);
//创建gender 格子
var td_gender = document.createElement("td");
var text_gender = document.createTextNode(gender);
td_gender.appendChild(text_gender);
tr.appendChild(td_gender);
//创建 操作格子
var td_option = document.createElement("td");
var a = document.createElement("a");
a.setAttribute("href","javascript:void(0);");
a.setAttribute("onclick","delTr(this)");
var text_a = document.createTextNode("删除");
a.appendChild(text_a);
td_option.appendChild(a);
tr.appendChild(td_option);
table.appendChild(tr);*/
}
//删除的方法
function delTr(obj) {
var tr = obj.parentNode.parentNode;
var table = tr.parentNode;
table.removeChild(tr);
}
</script>
</body>
</html>
HTMLDOM_innerHTML
-
标签体的内容设置和获取:innerHTML
-
示例代码
<script type="text/javascript">
var dv = document.getElementById("div1");
dv.innerHTML +="<input type='text'>"
</script>
HTMLDOM_样式控制
控制元素样式两种方式
-
使用元素的style属性来设置
//修改样式方式1
div1.style.border = "1px solid red";
div1.style.width = "200px";
//font-size--> fontSize
div1.style.fontSize = "20px";
- 提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。
var id2 = document.getElementById("div2");
id2.onclick = function () {
id2.className = "name";
}