1 <!DOCTYPE html>
2
3 <html lang="en" xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <meta charset="utf-8" />
6 <title></title>
7 <style type="text/css">
8 input { width: 100px; height: 25px; }
9 table { line-height: 30px; }
10 #add { width: 200px; height: 22px; }
11 input[type=checkbox] { width: 15px; height: 15px; vertical-align: middle; }
12 </style>
13 </head>
14
15
16 <body style="text-align:center;">
17
18
19
20 <table border="1">
21 <thead>
22 <tr>
23 <td><input id="all" type="checkbox" onclick="check();" />全选</td>
24 <th>品名</th>
25 <th>数量</th>
26 <th>单价</th>
27 <th>小计</th>
28 <th>操作</th>
29 </tr>
30
31 </thead>
32
33 <tbody id="biao">
34 <tr id="row0"><!--默认初始行-->
35 <td><input name="xuan" type="checkbox" /></td>
36 <td>大馒头</td>
37 <td>20</td>
38 <td>15.00</td>
39 <td></td>
40 <td><input id="del" type="button" value="删除" onclick="dele('row0')" /> <input id="xg" type="button" value="修改" onclick="editL('row0')" /></td>
41 </tr>
42 </tbody>
43 <tfoot>
44 <tr>
45 <td colspan="6"><input type="button" id="add" value="新增一行" onclick="xinzeng()" /></td>
46 </tr>
47 </tfoot>
48
49 </table>
50
51
52 </body>
53 </html>
54 <script type="text/javascript">
55
56 //默认初始行
57 var autoL = document.getElementById("row0").cells;
58 autoL[4].innerHTML = parseInt(autoL[2].innerHTML) * parseInt(autoL[3].innerHTML);
59
60
61 //循环新增行
62 function xinzeng() {
63 var table = document.getElementById("biao");//找到需要设置功能的表格
64
65 var h_index = table.rows.length;//指定插入行的位置
66 var hang = table.insertRow(h_index);//在指定位置插入新增行
67 hang.id = "row" + h_index;//给新增行添加ID
68
69 var lie1 = hang.insertCell(0);//给新增行插入列1
70 lie1.innerHTML = "<input name='xuan' type='checkbox' />";//新增行内容
71
72 var lie1 = hang.insertCell(1);//给新增行插入列2
73 lie1.innerHTML = "小馒头";//新增行内容
74
75 var lie2 = hang.insertCell(2);//给新增行插入列3
76 lie2.innerHTML = "20";//新增行内容
77
78 var lie3 = hang.insertCell(3);//给新增行插入列4
79 lie3.innerHTML = "15.00";//新增行内容
80
81 var lie4 = hang.insertCell(4);//给新增行插入列5
82 var prc = parseInt(lie2.innerHTML);//获取lie2的HTML内容,并转换为数字对象
83 var num = parseInt(lie3.innerHTML); //获取lie3的HTML内容,并转换为数字对象
84 lie4.innerHTML = prc * num;//计算两数字的积
85
86 var lie5 = hang.insertCell(5)//插入列6
87 var del = "<input id='del" + h_index + "' type='button' value='删除' onclick=\"dele('row" + h_index + "')\" />";//添加删除按钮,并注册删除事件
88 var mod = "<input id='mod" + h_index + "' type='button' value='修改' onclick=\"editL('row" + h_index + "')\" />";//添加修改按钮,并注册修改进入事件
89 lie5.innerHTML = del + " " + mod;
90 }
91
92 //删除事件
93 function dele(h_dw) {
94 var h = document.getElementById(h_dw).rowIndex - 1;//定位删除元素所处的行
95 document.getElementById("biao").deleteRow(h);//deleteEow(index) 方法用于从表格删除指定位置的行.
96 //注意:参数 index 指定了要删除的行在表中的位置。行的编码顺序就是他们在文档源代码中出现的顺序。<thead> 和 <tfoot> 中的行与表中其它行一起编码。
97 }
98
99 //修改进入事件
100 function editL(l_dw) {
101 var l = document.getElementById(l_dw).cells;//获取改行的单元格
102 text = l[2].innerHTML;//获取第三个单元格的HTML,用index定位
103 l[2].innerHTML = "<input type='text' value='" + text + "' style='width:30px' />";//改变它的HTML为可修改文本框
104 l[5].lastChild.value = "确定"; //改变修改按钮为确定按钮
105 l[5].lastChild.setAttribute("onclick", "upL('" + l_dw + "')")//给修改按钮注册确定事件,及修改退出事件
106 }
107
108 //修改退出事件
109 function upL(l_dw) {
110 var l = document.getElementById(l_dw).cells;//获取改行的单元格
111 text = l[2].firstChild.value;//获取第三个单元格内的值
112 l[2].innerHTML = text;//改变它的HTML为文本值
113 l[5].lastChild.value = "修改";//改变确定按钮为修改按钮
114 l[5].lastChild.setAttribute("onclick", "editL('" + l_dw + "')")//给修改按钮重新注册回修改进入事件
115 l[4].innerHTML = parseInt(l[2].innerHTML) * parseInt(l[3].innerHTML);//重新计算lie2与lie3的结果
116 }
117
118
119 //全选
120 function check() {
121 inputO = document.getElementsByName("xuan");//获取需要实现全选功能的按钮
122 for (i = 0; i < inputO.length; i++) {//循环,用此作为index,获取每一个inputO按钮
123 if (document.getElementById("all").checked == true) {//判断一个按钮处于选中状态时
124 inputO[i].checked = true;//所有按钮全部执行选中
125 } else {//否则
126 inputO[i].checked = false;//所有按钮全部执行未选中
127 }
128 }
129
130 }
131
132 </script>