【前端】JavaScript入门及实战101-105

101 DOM查询的其他方法

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">	
	<script type="text/javascript">	
		window.onload = function(){
			// 获取body标签
			//var body = document.getElementsByTagName("body")[0];
			
			/*
				在document中有一个属性body,他保存的是body的引用
			*/
			var body = document.body;
			
			/*
				document.documentElement保存的是html根标签
			*/
			var html = document.documentElement;
			
			/*
				document.all保存页面中所有元素
			*/
			var all = document.all;
			all = document.getElementsByTagName("*"); // *:所有元素
			
			/*
				根据元素的class属性值查询一组元素节点对象
				getElementsByClassName()可以根据class属性值获取一组元素节点对象,
				该方法不支持IE8及以下浏览器
			*/
			var box1 = document.getElementsByClassName("box1");
			
			// 获取页面中所有的div
			var divs = document.getElementsByTagName("div");
			
			// 获取class为box1中所有的div
			// .box1 div
			/*
				document.querySelector()
				需要一个选择器的字符串作为参数,可以根据一个CSS选择器来查询一个元素节点对象
				
				虽然IE8中没有document.getElementsByClassName()但是可以使用document.querySelector()代替
				使用该方法总会返回唯一的一个元素,如果满足条件的元素有多个,那么只会返回第一个
			*/
			var div = document.querySelector(".box1 div");
			
			var box1 = document.querySelector(".box1");
			
			/*
				document.querySelectorAll()
				该方法和querySelectorAll()用法类似,不同的是它会将符合条件的元素封装到一个数组中返回
				即使符合条件的只有一个,也会返回数组
			*/
			var box1 = document.querySelectorAll(".box1");
			var box1 = document.querySelectorAll("#box1");
		};				
	</script>	
</head>
<body>
	<div class="box1">
		<div>我是box1中的div</div>
	</div>
	<div class="box1">
		<div>我是box1中的div</div>
	</div>
	<div id="box1">
		<div>我是box1中的div</div>
	</div>	
</body>
</html>

102 DOM增删改

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">	
	<script type="text/javascript">	
		function myClick(idStr, fun) {
			var btn = document.getElementById(idStr);
			btn.onclick = fun;
		}

		window.onload = function(){		
			// 创建一个“广场”节点,添加到#city下
			myClick("btn01", function(){
				// 创建广州节点<li>广州</li>
				// 创建li元素节点
				/*
					document.createElement()
						可以用于创建一个元素节点对象,
						他需要一个标签名作为参数,将会根据该标签名创建元素节点对象,
						并将创建好的对象作为返回值返回
				*/
				var li = document.createElement("li");
				
				// 创建广州文本节点
				/*
					document.createTextNode()
						可以用来创建一个文本节点对象,
						需要一个文本内容作为参数,将会根据该内容创建文本节点,并将新的节点返回
				*/
				var gzText = document.createTextNode("广州");
				
				// 将gzText设置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");
				
				// 获取id为city的节点
				var city = document.getElementById("city");
				
				/*
					insertBefore()
						可以在指定的子节点前插入新的子节点
						语法:父节点.insertBefore(新节点,指定节点);
				*/
				city.insertBefore(li, bj);							
			});
			
			// 使用“广州”节点替换#bj节点
			myClick("btn03", function(){
				// 创建一个广州
				var li = document.createElement("li");
				var gzText = document.createTextNode("广州");
				li.appendChild(gzText);
				
				// 获取id为bj的节点
				var bj = document.getElementById("bj");
				
				// 获取id为city的节点
				var city = document.getElementById("city");
				
				/*
					replaceChild()
						可以使用指定的子节点替换已有的子节点
						语法:父节点.replaceChild(新节点,旧节点);
				*/
				city.replaceChild(li, bj);
			});
						
			// 删除#bj节点
			myClick("btn04", function(){
				// 获取id为bj的节点
				var bj = document.getElementById("bj");
				
				// 获取id为city的节点
				var city = document.getElementById("city");
				
				/*
					removeChild()
						可以删除一个子节点
						语法:父节点.removeChild(子节点);
						
					子节点.parentNode.removeChild(子节点);
				*/
				//city.removeChild(bj);
				
				bj.parentNode.removeChild(bj);
			});
			
			// 读取#city内的HTML代码
			myClick("btn05", function(){
				// 获取id为city的节点
				var city = document.getElementById("city");
				
				alert(city.innerHTML);
			});
			
			// 设置#bj内的HTML代码
			myClick("btn06", function(){
				// 获取id为bj的节点
				var bj = document.getElementById("bj");
				bj.innerHTML = "昌平";
			});
			
			myClick("btn07", function(){
				// 向city中添加广州
				var city = document.getElementById("city");
				
				/*
					使用innerHTML也可以完成DOM的增删改相关操作
					一般我们会两种方式结合使用
				*/
				//city.innerHTML += "<li>广州</li>";
				
				// 创建一个li
				var li = document.createElement("li");
				// 向li中设置文本
				li.innerHTML = "广州";
				// 将li添加到city中
				city.appendChild(li);
			});						
		};
	</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下(innerHTML)</button></div>
	</div>
</body>
</html>

103 添加删除记录-删除

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">	
	<script type="text/javascript">	
		window.onload = function(){
			/*
				点击超链接以后,删除一个员工的信息			
			*/
			// 获取所有超链接
			var allA = document.getElementsByTagName("a");
			
			// 为每个超链接绑定一个单击响应函数
			for(var i = 0; i < allA.length; i++){
				allA[i].onclick = function(){
					
					// 点击超链接以后需要删除超链接所在行
					// 这里我们点击那个超链接this就是谁
					// 获取当前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					
				};
			}
		};				
	</script>	
</head>
<body>
	<table id="employeeTable">
		<tr>
			<th>Name</th>
			<th>Email</th>
			<th>Salary</th>
			<th>&nbsp;</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>jerry@sohu.com</td>
			<td>8000</td>
			<td><a href="deleteEmp?id=002">Delete</a></td>
		</tr>
		<tr>
			<td>Bob</td>
			<td>bob@tom.com</td>
			<td>10000</td>
			<td><a href="deleteEmp?id=003">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" name="email" id="email" />
				</td>
			</tr>
			<tr>
				<td class="word">salary: </td>
				<td class="inp">
					<input type="text" name="salary" id="salary" />
				</td>
			</tr>
			<tr>
				<td colspan="2" align="center">
					<button id="addEmpButton" value="abc">
						Submit
					</button>
				</td>
			</tr>
		</table>
	</div>
</body>
</html>

104 添加删除记录-添加

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">	
	<script type="text/javascript">	
		/*
			删除tr的响应函数
		*/
		function delA(){
			// 点击超链接以后需要删除超链接所在行
			// 这里我们点击那个超链接this就是谁
			// 获取当前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					
		}
		
		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;
			
				// 将获取到的信息保存到tr中
				// 创建一个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;
				
				// 获取table
				var employeeTable = document.getElementById("employeeTable");
				// 获取employeeTable中的tbody
				/*
					<table>
						<tbody>
							<tr>
								<td></td>
								<td></td>
								<td></td>
							</tr>
							<tr>
								<td></td>
								<td></td>
								<td></td>
							</tr>
						</tbody>
					</table>
				*/
				var tbody = employeeTable.getElementsByTagName("tbody")[0];
				// 将tr添加到table中
				//employeeTable.appendChild(tr);
				// 将tr添加到tbody中
				tbody.appendChild(tr);
			}
		};				
	</script>	
</head>
<body>
	<table id="employeeTable">
		<tr>
			<th>Name</th>
			<th>Email</th>
			<th>Salary</th>
			<th>&nbsp;</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>jerry@sohu.com</td>
			<td>8000</td>
			<td><a href="deleteEmp?id=002">Delete</a></td>
		</tr>
		<tr>
			<td>Bob</td>
			<td>bob@tom.com</td>
			<td>10000</td>
			<td><a href="deleteEmp?id=003">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" name="email" id="email" />
				</td>
			</tr>
			<tr>
				<td class="word">salary: </td>
				<td class="inp">
					<input type="text" name="salary" id="salary" />
				</td>
			</tr>
			<tr>
				<td colspan="2" align="center">
					<button id="addEmpButton" value="abc">
						Submit
					</button>
				</td>
			</tr>
		</table>
	</div>
</body>
</html>

105 添加删除记录-修改

<!DOCTYPE html>
<html>
<head>
<title></title>
<meta charset="utf-8">	
	<script type="text/javascript">	
		/*
			删除tr的响应函数
		*/
		function delA(){
			// 点击超链接以后需要删除超链接所在行
			// 这里我们点击那个超链接this就是谁
			// 获取当前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					
		}
		
		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;
			
				// 将获取到的信息保存到tr中
				// 创建一个tr
				var tr = document.createElement("tr");
				
				// 设置tr中的内容
				tr.innerHTML = "<td>" + name + "</td>" +  
							   "<td>" + email + "</td>" + 
							   "<td>" + salary + "</td>" + 
							   "<td><a href='javascript:;'>Delete</a></td>";
				
				// 获取刚刚添加的a元素,并绑定单击响应函数
				var a = tr.getElementsByTagName("a")[0];
				a.onclick = delA;
								
				// 获取table
				var employeeTable = document.getElementById("employeeTable");
				// 获取employeeTable中的tbody
				/*
					<table>
						<tbody>
							<tr>
								<td></td>
								<td></td>
								<td></td>
							</tr>
							<tr>
								<td></td>
								<td></td>
								<td></td>
							</tr>
						</tbody>
					</table>
				*/
				var tbody = employeeTable.getElementsByTagName("tbody")[0];
				// 将tr添加到table中
				//employeeTable.appendChild(tr);
				// 将tr添加到tbody中
				tbody.appendChild(tr);
				/*
					tbody.innerHTML += "<td>" + name + "</td>" +  
									   "<td>" + email + "</td>" + 
									   "<td>" + salary + "</td>" + 
									   "<td><a href='javascript:;'>Delete</a></td>";
				*/
			}
		};				
	</script>	
</head>
<body>
	<table id="employeeTable">
		<tr>
			<th>Name</th>
			<th>Email</th>
			<th>Salary</th>
			<th>&nbsp;</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>jerry@sohu.com</td>
			<td>8000</td>
			<td><a href="deleteEmp?id=002">Delete</a></td>
		</tr>
		<tr>
			<td>Bob</td>
			<td>bob@tom.com</td>
			<td>10000</td>
			<td><a href="deleteEmp?id=003">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" name="email" id="email" />
				</td>
			</tr>
			<tr>
				<td class="word">salary: </td>
				<td class="inp">
					<input type="text" name="salary" id="salary" />
				</td>
			</tr>
			<tr>
				<td colspan="2" align="center">
					<button id="addEmpButton" value="abc">
						Submit
					</button>
				</td>
			</tr>
		</table>
	</div>
</body>
</html>
  • 26
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值