12-关于DOM操作的相关案例
1,模态框案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
*{
padding: 0;
margin: 0;
}
html, body{
height: 100%;
}
#box{
width: 100%;
height: 100%;
background: rgba(0,0,0,.3);
}
#content{
position: relative;
top: 150px;
width: 400px;
height: 200px;
line-height: 200px;
text-align: center;
color: red;
background-color: #fff;
margin: auto;
}
#span1{
position: absolute;
background-color: red;
top: 0;
right: 0;
width: 30px;
height: 30px;
line-height: 30px;
text-align: center;
color: #fff;
}
</style>
</head>
<body>
<button id="btn">弹出</button>
</body>
<script>
//获取dom元素,1获取事件源
var oBtn = document.getElementById('btn');
//创建弹出模态框的相关DOM对象
var oDiv = document.createElement("div");
var oP = document.createElement("p");
var oSpan = document.createElement("span")
//设置属性
oDiv.id = "box";
oP.id = 'content';
oP.innerHTML = "模态框弹出";
oSpan.innerHTML = "X";
oSpan.id = 'span1'
//追加元素
oDiv.appendChild(oP);
oP.appendChild(oSpan);
//点击弹出按钮 弹出模态框
oBtn.onclick = function(){
//动态的添加到body中一个div
this.parentNode.insertBefore(oDiv, btn)
}
//点击x关闭模态框
oSpan.onclick = function(){
//移除oDiv元素
oDiv.parentNode.removeChild(oDiv)
}
</script>
</html>
2,建议留言板
需求:
当再textarea中输入内容,点击留言板按钮,会添加到浏览器中
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
*{
padding: 0;
margin: 0;
}
.close{
display: inline-block;
width: 20px;
height: 20px;
line-height: 20px;
text-align: center;
cursor: pointer;
background-color: rgba(0,0,0,.1);
margin-left: 20px;
}
</style>
</head>
<body>
<h1>简易留言板</h1>
<div id="box">
</div>
<textarea id="msg"></textarea>
<input type="button" id="btn" value="留言"/>
<button onclick="sum()">统计</button>
</body>
<script>
// 将ul标签添加到div#box标签中
var oUl = document.createElement("ul");
var oBox = document.getElementById("box");
oBox.appendChild(oUl);
var oBtn = document.getElementById('btn');
var oMsg = document.getElementById('msg');
//控制留言的总数量
var count = 0;
oBtn.onclick = function(){
//点击留言按钮事件操作
//1.创建li标签
var oLi = document.createElement("li");
//2 设置内容
oLi.innerHTML = oMsg.value + "<span class='close'>X</span>";
//3 如果想再插入的第一个li获取的前面继续添加li标签
//3.1获取li标签
var olis = document.getElementsByTagName('li');
//3.2 如果是第一次添加的li标签,则直接添加ul的后面
if(olis.length == 0){
oUl.appendChild(oLi);
count++;
}else {
//3.3 如果不是第一次添加的li标签,则插入到第一个li标签的前面
oUl.insertBefore(oLi, olis[0]);
count++
}
//4,添加完之后,清空textarea的值
oMsg.value = '';
//5 点击X的时候删除当前的一条数据
//5.1先获取所有的X
var oSpans = document.getElementsByTagName('span');
//5.2 for循环 对所有的X添加点击事件
for(var i = 0; i < oSpans.length; i++){
oSpans[i].onclick = function(){
oUl.removeChild(this.parentNode);
count--;
}
}
}
function sum(){
alert("一共发布了"+count+"条留言")
}
</script>
</html>

浙公网安备 33010602011771号