js实现动态添加删除表格数据的两种方式

目录

1、通过创建节点实现

css代码

html代码

js代码

完整代码

2、通过渲染表格,事件委托实现

css代码

html代码

js代码

完整代码

效果图


1、通过创建节点实现

思路:先把整体的html结构写出来,table表格分为3部分,其中tbody中的内容通过节点创建出来,删除时,找到其祖先元素的节点进行remove(),表单内的各个框的值对应表格的内容。

css代码

html代码

姓名 科目 成绩 操作
总分:平均分:
姓名:
科目:
分数:

js代码

 

完整代码





    
    
    Document
    



    
姓名 科目 成绩 操作
总分:平均分:
姓名:
科目:
分数:

2、通过渲染表格,事件委托实现

思路:先把整体的效果图写出来,再通过js渲染到页面上,每次添加一组数据就相当于给数组添加数据,删除事件用事件委托,给祖先元素绑定事件,子元素触发事件会冒泡到祖先元素。

css代码

.score-case {
  width: 1000px;
  margin: 50px auto;
  display: flex;
}
.score-case .table {
  flex: 4;
}
.score-case .table table {
  width: 100%;
  border-spacing: 0;
  border-top: 1px solid #ccc;
  border-left: 1px solid #ccc;
}
.score-case .table table th {
  background: #f5f5f5;
}
.score-case .table table tr:hover td {
  background: #f5f5f5;
}
.score-case .table table td,
.score-case .table table th {
  border-bottom: 1px solid #ccc;
  border-right: 1px solid #ccc;
  text-align: center;
  padding: 10px;
}
.score-case .table table td.red,
.score-case .table table th.red {
  color: red;
}
.score-case .table .none {
  height: 100px;
  line-height: 100px;
  color: #999;
}
.score-case .form {
  flex: 1;
  padding: 20px;
}
.score-case .form .form-item {
  display: flex;
  margin-bottom: 20px;
  align-items: center;
}
.score-case .form .form-item .label {
  width: 60px;
  text-align: right;
  font-size: 14px;
}
.score-case .form .form-item .input {
  flex: 1;
}
.score-case .form .form-item input,
.score-case .form .form-item select {
  appearance: none;
  outline: none;
  border: 1px solid #ccc;
  width: 200px;
  height: 40px;
  box-sizing: border-box;
  padding: 10px;
  color: #666;
}
.score-case .form .form-item input::placeholder {
  color: #666;
}
.score-case .form .form-item .cancel,
.score-case .form .form-item .submit {
  appearance: none;
  outline: none;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 4px 10px;
  margin-right: 10px;
  font-size: 12px;
  background: #ccc;
}
.score-case .form .form-item .submit {
  border-color: #069;
  background: #069;
  color: #fff;
}

html代码

姓名 科目 成绩 操作
总分:246 平均分:79
姓名:
科目:
分数:

js代码

完整代码



  
    
    
    
    
    Document
  

  
    
姓名 科目 成绩 操作
总分:246 平均分:79
姓名:
科目:
分数:

效果图

js实现动态添加删除表格数据的两种方式_第1张图片

你可能感兴趣的:(js案例,javascript,开发语言,ecmascript)