<!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>
<style type="text/css">
* {
margin: 0;
padding: 0;
}
a {
text-decoration: none;
color:#721c24;
}
h1 {
text-align: center;
color:#333;
margin: 20px 0;
}
table {
margin:0 auto;
width: 800px;
border-collapse: collapse;
color:#004085;
}
th {
padding: 10px;
background: #cfe5ff;
font-size: 20px;
font-weight: 400;
}
td,th {
border:1px solid #b8daff;
}
td {
padding:10px;
color:#666;
text-align: center;
font-size: 16px;
}
tbody tr {
background: #fff;
}
tbody tr:hover {
background: #e1ecf8;
}
.info {
width: 900px;
margin: 50px auto;
text-align: center;
}
.info input {
width: 80px;
height: 25px;
outline: none;
border-radius: 5px;
border:1px solid #b8daff;
padding-left: 5px;
}
.info button {
width: 60px;
height: 25px;
background-color: #004085;
outline: none;
border: 0;
color: #fff;
cursor: pointer;
border-radius: 5px;
}
.info .age {
width: 50px;
}
</style>
</head>
<body>
<h1>新增学员</h1>
<div class="info">
姓名:<input type="text" class="uname"> 年龄:
<input type="text" class="age"> 性别:
<select name="gender" id="" class="gender">
<option value="男">男</option>
<option value="女">女</option>
</select> 薪资:
<input type="text" class="salary"> 就业城市:
<select name="city" id="" class="city">
<option value="北京">北京</option>
<option value="上海">上海</option>
<option value="广州">广州</option>
<option value="深圳">深圳</option>
<option value="新疆">新疆</option>
<option value="丽江">丽江</option>
<option value="拉萨">拉萨</option>
<option value="西藏">西藏</option>
</select>
<button class="add">录入</button>
</div>
<h1>就业榜</h1>
<table>
<thead>
<tr>
<th>学号</th>
<th>姓名</th>
<th>年龄</th>
<th>性别</th>
<th>薪资</th>
<th>就业城市</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<tr>
<td>1001</td>
<td>檀健次</td>
<td>31</td>
<td>男</td>
<td>1990</td>
<td>广西</td>
<td>
<a href=" ">删除</a >
</td>
</tr>
</tbody>
</table>
<script>
// 1. 准备阶段 利用 数组 模拟 数据
let arr = [{
stuId: 1001,
uname: '檀健次',
age: 31,
gender: '男',
salary: '1990',
city: '广西'
}, {
stuId: 1002,
uname: '易烊千玺',
age: 21,
gender: '男',
salary: '2000',
city: '湖南'
}, {
stuId: 1003,
uname: '杰哥',
age: 21,
gender: '男',
salary: '2002',
city: '安徽'
}];
//2.获取 tbody元素
let tbody =document.querySelector('tbody');
//添加数据按钮
//获取录入按钮
let add=document.querySelector('.add');
//获取各个表单的元素
let uname=document.querySelector('.uname');
let age=document.querySelector('.age');
let gender=document.querySelector('.gender');
let salary=document.querySelectorAll('.salary');
let city=document.querySelector('.city');
//3.1借助for循环 遍历数组arr
function render(){
tbody.innerHTML=''//让它为空
for (var i=0;i<arr.length;i++){
var tr=document.createElement('tr');
tr.innerHTML = `
<td>${arr[i].stuId}</td>
<td>${arr[i].uname}</td>
<td>${arr[i].age}</td>
<td>${arr[i].gender}</td>
<td>${arr[i].salary}</td>
<td>${arr[i].city}</td>
<td>
<a href="javascript:" id="${i}">删除</a>
</td>
`;
//3.4把tr追加到tbody里面 父元素.appendChild(子元素)
tbody.appendChild(tr);
}
}
//页面加载就调用函数
render();
// 注册点击事件
add.addEventListener('click', function() {
// alert('测试');
// 获得表单中的内容 添加到 arr push方法
// arr.push('测试');
// console.log(arr);
arr.push({
//得到数组最后一条数据的学号 ,1003再加1就是当前的学号
stuId: arr[arr.length - 1].stuId + 1,
uname: uname.value,
age: age.value,
gender: gender.value,
salary: salary.value,
city: city.value
});
//console.log(arr);
render();//重新渲染我们的数据
uname.value=age.value=salary.value='';
gender.value='男';
city.value='北京';
});
//输出数组中的数据 需要用到事件委托 事件对象e
tbody.addEventListener('click',function(e){
if (e.target.tagName ==='A'){
arr.splice(e.target.id,1);
render()
}
})
</script>
</body>
</html>
运行结果: