Javascript-商品管理新增/删除/修改功能

  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')" />&nbsp;<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 + "&nbsp;" + 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>

 

posted @ 2016-08-17 14:12  YanEr、  阅读(2605)  评论(0编辑  收藏  举报