国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

js 獲取掃碼槍輸入數據的方法

瀏覽:156日期:2024-05-04 16:12:27

1、掃碼槍相當于鍵盤輸入設備,輸入一連串數字后加一個enter鍵。但在實際開發中需要區分是掃描槍輸入還是鍵盤用戶輸入,區別在于掃碼槍輸入很快。

let code = ’’; let lastTime, nextTime; let lastCode, nextCode; window.document.onkeypress = (e) => { if (window.event) { // IE nextCode = e.keyCode; } else if (e.which) { // Netscape/Firefox/Opera nextCode = e.which; } if (nextCode === 13) { if (code.length < 3) return; // 手動輸入的時間不會讓code的長度大于2,所以這里只會對掃碼槍有 console.log(code); // 獲取到掃碼槍輸入的內容,做別的操作 code = ’’; lastCode = ’’; lastTime = ’’; return; } nextTime = new Date().getTime(); if (!lastTime && !lastCode) { code += e.key; } if (lastCode && lastTime && nextTime - lastTime > 30) { // 當掃碼前有keypress事件時,防止首字缺失 code = e.key; } else if (lastCode && lastTime) { code += e.key; } lastCode = nextCode; lastTime = nextTime; }

PS:下面看下js獲取USB掃碼槍數據的代碼

前言

找了很多相關的教程不太好用,汲取各家之長總結精簡了一下

原理

掃碼槍掃描到的條形碼每一位會觸發一次onkeydown事件 比如掃描條碼位‘1234567890’的條形碼,會連續執行10次onkeydown事件 條碼掃描到最后一位,會直接觸發Enter

需要引入jQuery,我這里用的是vue

window.onload = (e)=> { document.onkeydown = (e)=> { let nextCode,nextTime = ’’; let lastTime = this.lastTime; let code = this.code; if (window.event) {// IE nextCode = e.keyCode } else if (e.which) {// Netscape/Firefox/Opera nextCode = e.which } nextTime = new Date().getTime(); //字母上方 數字鍵0-9 對應鍵碼值 48-57; 數字鍵盤 數字鍵0-9 對應鍵碼值 96-105 if((nextCode>=48&&nextCode<=57) || (nextCode>=96&&nextCode<=105)){ let codes = {’48’:48,’49’:49,’50’:50,’51’:51,’52’:52,’53’:53,’54’:54,’55’:55,’56’:56,’57’:57, ’96’:48,’97’:49,’98’:50,’99’:51,’100’:52,’101’:53,’102’:54,’103’:55,’104’:56,’105’:57};nextCode = codes[nextCode];nextTime = new Date().getTime(); } // 第二次輸入延遲兩秒,刪除之前的數據重新計算 if(nextTime && lastTime && nextTime-lastTime>2000){code = String.fromCharCode(nextCode); }else{ code += String.fromCharCode(nextCode) } // 保存數據 this.nextCode = nextCode; this.lastTime = nextTime; this.code = code; // 鍵入Enter if(e.which == 13) { // 判斷 code 長度(這里就獲取到條碼值了,以下業務自由發揮) code = $.trim(code) if (code.length == 13) {this.$message(’A類條碼:’ + code); } else if (code.length == 23) {this.$message(’B類條碼:’ + code); } else if (code.length == 0) {this.$message(’請輸入條碼’); } else{ this.$message(’條碼不合法:’ + code); } //鍵入回車務必清空code值 this.code = ’’ return false; } }}

總結

到此這篇關于js 獲取掃碼槍輸入數據的文章就介紹到這了,更多相關js 獲取掃碼槍輸入數據內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美高清一区二区三区欧美 | 成年人www| 亚洲国产第一区二区香蕉日日 | 在线精品国产三级 | 免费在线成人 | 久久午夜影视 | 欧美日韩精品免费一区二区三区 | 舔操| 国产香蕉国产精品偷在线观看 | 成人在线精品 | 日本一级大黄毛片免费基地 | 国产高清亚洲 | 欧美成人se01短视频在线看 | 国产xvideos国产在线 | 亚洲资源在线观看 | 黄色不卡视频 | 激情丝袜美女视频二区 | 手机看成人片 | 免费观看一级成人毛片软件 | 高清不卡毛片免费观看 | 欧美成人免费网在线观看 | 国产一级内谢a级高清毛片 国产一级片毛片 | 欧美一区二区亚洲 | 老头老太做爰xxx视频 | 在线第一页 | 欧美黄视频网站 | 久久看视频 | 欧美高清色视频在线播放 | 亚洲国产精品日韩在线观看 | 国产女人伦码一区二区三区不卡 | 女人被男人桶 | 亚洲天堂视频网 | 中文字幕人成不卡一区 | 久久天天躁综合夜夜黑人鲁色 | 亚洲欧美另类在线视频 | 精品亚洲视频在线观看 | 久久久免费观看视频 | 亚洲一区二区三区精品视频 | 日本欧美一区二区三区不卡视频 | 18video9ex欧美生活片 | 一级做a爱片久久毛片 |