目录
dom的其他查询方法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<script>
window.onload = function () {
// 获取body标签
var body = document.getElementsByTagName("body")[0];
// 在document中有一个属性body,它保存的是body的引用
alert(body); //[object HTMLBodyElement]
var body = document.body;
alert(body); //[object HTMLBodyElement]
var html = document.documentElement;
alert(html);
// document.all代表页面中的所有元素
var all = document.all;
console.log(all.length);
for (var i = 0; i < all.length; i++) {
console.log(all[i]);
}
all = document.getElementsByTagName("*");
console.log(all.length);
// 根据元素的class属性查询一些元素节点对象
// getElementsByClassName()可以根据class属性获取一组元素节点对象
// 但是该方法不支持IE8及以下的浏览器
// 根据元素的class属性值查询一组元素节点对象
// getElementsByClassName()可以根据class属性值获取一组元素节点对象
// 但是这种方法不知=支持IE8以下的浏览器
var box1 = document.getElementsByClassName("box1");
console.log(box1.length);
// 获取页面中的所有的div
var divs = document.getElementsByTagName("div");
console.log(divs.length);
// 获取box1中的div
// document.querySelector()
// 需要一个选择器的字符串作为参数,
// 可以根据一个css选择器来查询一个元素节点对象
// 使用该方法总会返回唯一的元素,如果满足条件的元素有多个,
// 则它只会返回第一个
var div = document.querySelector(".box1 div");
var box1 = document.querySelector(".box1");
console.log(box1.innerHTML);
console.log(div.innerHTML);
// document.querySelectorAll()
// 该方法和querySelector()语法类似,
// 不同的是它会将符合条件的元素封装到一个数组中返回
// 即使符合条件的元素只有一个,他也会返回数组
box1 = document.querySelectorAll(".box1");
box1 = document.querySelectorAll("#box2");
console.log(box1);
console.log(box1.length);
};
</script>
</head>
<body>
<div id="box2">box2</div>
<div class="box1">
我是第一个box1
<div>我是box1中的div</div>
</div>
<div class="box1">
<div>我是box1中的div</div>
</div>
<div class="box1">
<div>我是box1中的div</div>
</div>
<div></div>
</body>
</html>
dom增删改
修改:
- confirm()用于弹出一个带有确认和取消按钮的提示框,需要一个字符串作为参数,该字符串将会作为提示文字显示出来。
- 如果用户点击确认会返回true,如果点击取消返回false。
- 点击超链接以后,超链接会跳转页面,是超链接的默认行为,但是不希望出现默认行为时,可以通过在响应函数的最后return false来取消默认行为。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<script>
window.onload = function () {
// 创建一个“广州”节点,添加到#city<
myClick("btn01", function () {
// alert("helo");
// 创建li元素节点
/*document.createElement()
可以创建一个标签名作为参数,将会根据该标签名创建元素节点对象
他需要一个标签名作为参数,将会根据该标签名创建元素节点对象,
并将创建好的对象作为返回值返回
*/
var li = document.createElement("li");
// 创建广州文本节点
// document.=document.createTextNode()
// 可以用来创建一个文本节点对象
// 需要一个文本内容作为参数,将会根据该内容创建文本节点,
// 并将新的节点返回
var gzText = document.createTextNode("广州");
/* 将geText设置li的子节点
appendChild()
向一个父节点中添加新的子节点
用法:父节点.appendChild(子节点)
*/
li.appendChild(gzText);
// 添加到#city<
// 获取id为city的节点
var city = document.getElementById("city");
city.appendChild(li);
});
// 将“广州”节点插入到#bj前面
myClick("btn02", function () {
var li = document.createElement("li");
var gzText = document.createTextNode("广州");
li.appendChild(gzText);
// 获取id为bj的节点
var bj = document.getElementById("bj");
// 获取city
var city = document.getElementById("city");
/*
insertBefore
可以在指定的子节点前插入新的子节点
语法:
父节点.insertBefore(新节点,旧节点)
*/
city.insertBefore(li, bj);
});
myClick("btn03", function () {
var li = document.createElement("li");
var gzText = document.createTextNode("广州");
li.appendChild(gzText);
// 获取id为bj的节点
var bj = document.getElementById("bj");
// 获取city
var city = document.getElementById("city");
/* replaceChild()
可以用来使用指定的子节点替换已有的子节点
语法:
父节点.replaceChild(新节点,子节点)
*/
city.replaceChild(li, bj);
});
// 删除#bj节点
myClick("btn04",function(){
// var bj=document.getElementById("bj");
// var city=document.getElementById("city");
// /* removeChild()
// 可以删除一个子节点
// 语法:父节点.removeChild(子节点);
// */
// city.removeChild(bj);
// 另一种方法
bj.parentNode.removeChild("bj");
})
myClick("btn05",function(){
// 获取city
var city=document.getElementById("city");
alert(city.innerHTML);
});
myClick("btn06",function(){
var bj=document.getElementById("bj");
bj.innerHTML="赣州";
})
myClick("btn07",function(){
var city=document.getElementById("city");
city.innerHTML+="<li>广州</li>";
});
};
function myClick(idStr, fun) {
var btn = document.getElementById(idStr);
btn.onclick = fun;
}
</script>
</head>
<body>
<div id="total">
<div class="inner">
<p>你喜欢哪个城市?</p>
<ul id="city">
<li id="bj">北京</li>
<li>上海</li>
<li>东京</li>
<li>首尔</li>
</ul>
</div>
</div>
<div id="btnList">
<div><button id="btn01">创建一个“广州”节点,添加到#city</button></div>
<div><button id="btn02">将“广州”节点插入到#bj前面</button></div>
<div><button id="btn03">使用“广州”节点替换#bj节点</button></div>
<div><button id="btn04">删除#bj节点</button></div>
<div><button id="btn05">读取#city内的Html代码</button></div>
<div><button id="btn06">设置#bj内的HTML代码</button></div>
<div><button id="btn07">创建一个“广州”节点,添加到#city</button></div>
</div>
</body>
</html>
添加删除记录
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>添加删除记录练习</title>
<script>
/*
删除tr的响应函数
*/
function delA(){
//点击a删除tr
// 获取当前tr
var tr=this.parentNode.parentNode;
// 删除之前弹出一个提示框
// 获取要删除的员工的名字
var name=tr.getElementsByTagName("td")[0].innerHTML;
// var name=tr.children[0].innerHTML;
/*
confirm()
用于弹出一个带有确认和取消按钮的提示框
需要一个字符串作为参数,该字符串作为提示文字显示出来
如果用户确认,则返回true
如果用户取消,则返回false
*/
var flag=confirm("确认删除"+name+"吗?");
// 如果用户点击确定
if(flag){
// 删除tr
tr.parentNode.removeChild(tr);
}
return false;
// 点击链接后,超链接回跳转页面,
// 这个是超链接的默认行为
// 不希望出现默认行为,可以通过在响应函数的最后
// return false
// 来取消默认行为
// 也可以在用javascript:;
};
window.onload = function () {
/*
点击超链接,删除员工的信息
*/
// 获取超链接以后,删除一个员工的信息
var allA=document.getElementsByTagName("a");
// 为每个超链接都绑定一个单击响应函数
for(var i=0;i<allA.length;i++){
allA[i].onclick=delA;
};
// 是赋值给对象,函数值
/*
添加员工
点击按钮,将员工的信息添加到表格中
*/
// 为按钮绑定一个单击响应函数
var addEmpButton=document.getElementById("addEmpButton");
addEmpButton.onclick=function(){
// 获取员工的名字
var name=document.getElementById("empName").value;
// 获取员工的email和salary
var email=document.getElementById("email").value;
var salary=document.getElementById("salary").value;
// alert(name+email+salary);
// 创建tr
var tr=document.createElement("tr");
// 该创建方法笨拙,需要采取新方法
// // 创建四个td
// var nameTd=document.createElement("td");
// var emailTd=document.createElement("td");
// var salaryTd=document.createElement("td");
// var aTd=document.createElement("td");
// // 创建a元素
// var a=document.createElement("a");
// // 创建文本节点
// var nameText=document.createTextNode(name);
// var emailText=document.createTextNode(email);
// var salaryText=document.createTextNode(salary);
// var delText=document.createTextNode("Delete");
// // 将文本条件到td中
// nameTd.appendChild(nameText);
// emailTd.appendChild(emailText);
// salaryTd.appendChild(salaryText);
// // 向a节点添加文本
// a.appendChild(delText);
// // 将a添加到td中
// aTd.appendChild(a);
// // 将td添加到tr中
// tr.appendChild(nameTd);
// tr.appendChild(emailTd);
// tr.appendChild(salaryTd);
// tr.appendChild(aTd);
// // 向a中添加到href属性
// a.href="javascript:;";
// // 为新添加的a再绑定一次单击响应函数
// a.onclick=delA;
// 设置tr中的内容
tr.innerHTML="<td>"+name+"</td>"+
"<td>"+email+"</td>"+
"<td>"+salary+"</td>"+
"<td><a href='javascript:;'>Delete</td>";
// 获取tr中的a节点,标并且跟他单击响应函数
var a=tr.getElementsByTagName("a")[0];
a.onclick=delA;
// 获取table
var employeeTable=document.getElementById("employeeTable");
// 获取employeeTable中的tbody
var tbody=employeeTable.getElementsByTagName("tbody")[0];
// 将tr添加到table中
tbody.appendChild(tr);
}
}
</script>
</head>
<body>
<table id="employeeTable">
<tr>
<th>Name</th>
<th>Email</th>
<th>Salary</th>
<th> </th>
</tr>
<tr>
<td>Tom</td>
<td>tom@tom.com</td>
<td>5000</td>
<td><a href="javascript:;">Delete</a></td>
</tr>
<tr>
<td>Jerry</td>
<td>Terry@sohu.com</td>
<td>8000</td>
<td><a href="javascript:;">Delete</a></td>
</tr>
<tr>
<td>Bob</td>
<td>Bob@tom.com</td>
<td>10000</td>
<td><a href="javascript:;">Delete</a></td>
</tr>
</table>
<div id="formDiv">
<h4>添加新员工</h4>
<table>
<tr>
<td class="word">name:</td>
<td class="inp">
<input type="text" name="empName" id="empName" />
</td>
</tr>
<tr>
<td class="word">email:</td>
<td class="inp">
<input type="text" id="email" name="email"></input>
</td>
</tr>
<tr>
<td class="word">salary:</td>
<td class="inp">
<input type="text" id="salary" name="salary"></input>
</td>
</tr>
<tr>
<td colspan="2" align="center">
<button id="addEmpButton">
Submit
</button>
</td>
</tr>
</table>
</div>
</body>
</html>
for循环在页面加载完成之后立即执行
响应函数会在超链接被点击时才执行 当响应函数执行时,for循环早已执行完毕