localStorage本地存儲數組、讀取、修改、刪除

應用場景:用於記錄掃碼槍獲取的編碼數據,並存儲在本地、計數。可修改,可導出excel。css

 

  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>Scanning</title>
  6 <style>
  7 input{width:600px;height:38px;line-height: 38px;font-size: 32px;border:1px solid #ccc;outline: none;}
  8 table{font-size: 14px;margin:20px 0;}
  9 table,table tr,table tr td{border-collapse: collapse;border-spacing: 0;border:1px solid #ccc;}
 10 td{padding:5px;}
 11 .operation{ text-align: center;}
 12 .operation button{ margin: 0 5px;}
 13 #export{ width: 604px; display: block; line-height: 30px; margin-bottom: 30px;}
 14 </style>
 15 </head>
 16 <body>
 17 
 18 <input type="textbox" id="coding" maxlength="24" />
 19 <table id="table-main">
 20     <tr id="num-data">
 21         <td width="220">編號</td>
 22         <td width="100">尺碼</td>
 23         <td width="100">數量</td>
 24         <td width="139">操做</td>
 25     </tr>
 26 </table>
 27 <button id="export">導出數據</button>
 28 <button id="clear">清除</button>
 29 <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
 30 <script>
 31     
 32 document.onkeydown=function(event){
 33     var e = event || window.event || arguments.callee.caller.arguments[0];
 34     if(e && e.keyCode==13){    
 35         var _code=$("#coding").val();
 36         if(_code){
 37             var _size=_code.substr(-3);
 38             var _index=$.inArray(_code,local.code);
 39             if(_index=='-1'){
 40                 var _num=1;
 41                 local.data(_code,_num);
 42                 local.addtd(_code,_size,_num);
 43             }else{
 44                 var _num=Number(local.num[_index])+1;
 45                 local.data(_index,_num,'modify');
 46                 $('.code').each(function(){
 47                     if($(this).text()==_code){
 48                         $(this).siblings('.num').text(_num);
 49                         return;
 50                     }
 51                 });
 52             }
 53         }else{
 54             alert('編碼錯誤!');
 55         }
 56         $('#coding').val('').focus();
 57     }else{
 58         $('#coding').focus();
 59     }
 60 }; 
 61 
 62 var local={
 63     //存儲的數組
 64     code:[],
 65     num:[],
 66     //存儲方法
 67     data:function(code,num,modify){
 68         if(localStorage.code&&localStorage.num){
 69             local.code=local.read('code');
 70             local.num=local.read('num');
 71         }
 72         if(modify=='modify'){
 73             local.num[code]=num;
 74             localStorage.num=local.num;
 75         }else{
 76             local.code.push(code);
 77             local.num.push(num);
 78             localStorage.code=local.code;
 79             localStorage.num=local.num;
 80         }
 81     },
 82     //讀取數組方法
 83     read:function(type){
 84         if(localStorage.code&&localStorage.num){
 85             if(type=='code'){
 86                 var str=localStorage.code;
 87                 return str.split(",");
 88             }else{
 89                 var str=localStorage.num;
 90                 return str.split(",");
 91             }
 92         }else{
 93             return false;
 94         }
 95     },
 96     //清除方法
 97     remove:function(){
 98         localStorage.clear();
 99         local.code=[];
100         local.num=[];
101         history.go(0);
102     },
103     //添加數據元素
104     addtd:function(code,size,num){
105         $('#num-data').after(
106             "<tr>"+
107                 "<td class='code'>"+code+"</td>"+
108                 "<td class='size'>"+size+"</td>"+
109                 "<td class='num'>"+num+"</td>"+
110                 "<td class='operation'><button class='mod'>修改</button><button class='del'>刪除</button></td>"+
111             "</tr>"
112         );
113     },
114     //初始化
115     innt:function(){
116         $("#coding").focus();
117         var code=local.read('code');
118         var num=local.read('num');
119         if(code){
120             local.code=local.read('code');
121             local.num=local.read('num');
122             for(var i=0;i<code.length;i++){
123                 var size=code[i].substr(-3);
124                 local.addtd(code[i],size,num[i]);
125             }
126         }
127     }
128 };
129 
130 var exp={
131     idTmr:null,
132     getExplorer:function(){
133         var explorer = window.navigator.userAgent ;
134         if (explorer.indexOf("MSIE") >= 0) {
135             return 'ie';
136         }
137         else if (explorer.indexOf("Firefox") >= 0) {
138             return 'Firefox';
139         }
140         else if(explorer.indexOf("Chrome") >= 0){
141             return 'Chrome';
142         }
143         else if(explorer.indexOf("Opera") >= 0){
144             return 'Opera';
145         }
146         else if(explorer.indexOf("Safari") >= 0){
147             return 'Safari';
148         }
149     },
150     method:function(tableid){
151         if(exp.getExplorer()=='ie'){
152             var curTbl = document.getElementById(tableid);
153             var oXL = new ActiveXObject("Excel.Application");
154             var oWB = oXL.Workbooks.Add();
155             var xlsheet = oWB.Worksheets(1);
156             var sel = document.body.createTextRange();
157             sel.moveToElementText(curTbl);
158             sel.select();
159             sel.execCommand("Copy");
160             xlsheet.Paste();
161             oXL.Visible = true;
162             try{
163                 var fname = oXL.Application.GetSaveAsFilename("Excel.xls", "Excel Spreadsheets (*.xls), *.xls");
164             }catch(e){
165                 print("Nested catch caught " + e);
166             }finally{
167                 oWB.SaveAs(fname);
168                 oWB.Close(savechanges = false);
169                 oXL.Quit();
170                 oXL = null;
171                 exp.idTmr = window.setInterval("exp.Cleanup();", 1);
172             }
173         }else{
174             exp.tableToExcel(tableid)
175         }
176     },
177     Cleanup:function(){
178         window.clearInterval(exp.idTmr);
179         CollectGarbage();
180     },
181     tableToExcel:(function(){
182         var uri = 'data:application/vnd.ms-excel;base64,',
183                 template = '<html><head><meta charset="UTF-8"></head><body><table>{table}</table></body></html>',
184                 base64 = function(s){ return window.btoa(unescape(encodeURIComponent(s))) },
185                 format = function(s, c){
186                     return s.replace(/{(\w+)}/g,
187                             function(m, p) { return c[p]; }) }
188         return function(table, name) {
189             if(!table.nodeType) table = document.getElementById(table)
190             var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
191             window.location.href = uri + base64(format(template, ctx))
192         }
193     })()
194 }
195 
196 //初始化
197 local.innt();
198 
199 //導出excel
200 $('#export').click(function(){
201     exp.method('table-main');
202 });
203 
204 //刪除/修改
205 $(document).on('click','.operation button',function(){
206     var pet=$(this).parents('tr');
207     var code=pet.find('.code').text();
208     var index=$.inArray(code,local.code);
209     if($(this).hasClass('del')){
210         if(confirm("肯定要刪除這條數據?")){
211             local.code.splice(index,1);
212             local.num.splice(index,1);
213             pet.remove();
214             localStorage.code=local.code;
215             localStorage.num=local.num;
216         }
217     }else{
218         var pro=prompt('修改數量',local.num[index]);
219         local.num[index]=pro;
220         localStorage.num=local.num;
221         pet.find('.num').text(pro);
222     }
223 });
224 
225 //清除,測試用,可去掉
226 $('#clear').click(function(){
227     local.remove();
228 });
229 </script>
230 </body>
231 </html>
相關文章
相關標籤/搜索