亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

js 獲取掃碼槍輸入數(shù)據(jù)的方法

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

1、掃碼槍相當(dāng)于鍵盤輸入設(shè)備,輸入一連串?dāng)?shù)字后加一個(gè)enter鍵。但在實(shí)際開(kāi)發(fā)中需要區(qū)分是掃描槍輸入還是鍵盤用戶輸入,區(qū)別在于掃碼槍輸入很快。

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; // 手動(dòng)輸入的時(shí)間不會(huì)讓code的長(zhǎng)度大于2,所以這里只會(huì)對(duì)掃碼槍有 console.log(code); // 獲取到掃碼槍輸入的內(nèi)容,做別的操作 code = ’’; lastCode = ’’; lastTime = ’’; return; } nextTime = new Date().getTime(); if (!lastTime && !lastCode) { code += e.key; } if (lastCode && lastTime && nextTime - lastTime > 30) { // 當(dāng)掃碼前有keypress事件時(shí),防止首字缺失 code = e.key; } else if (lastCode && lastTime) { code += e.key; } lastCode = nextCode; lastTime = nextTime; }

PS:下面看下js獲取USB掃碼槍數(shù)據(jù)的代碼

前言

找了很多相關(guān)的教程不太好用,汲取各家之長(zhǎng)總結(jié)精簡(jiǎn)了一下

原理

掃碼槍掃描到的條形碼每一位會(huì)觸發(fā)一次onkeydown事件 比如掃描條碼位‘1234567890’的條形碼,會(huì)連續(xù)執(zhí)行10次onkeydown事件 條碼掃描到最后一位,會(huì)直接觸發(fā)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(); //字母上方 數(shù)字鍵0-9 對(duì)應(yīng)鍵碼值 48-57; 數(shù)字鍵盤 數(shù)字鍵0-9 對(duì)應(yīng)鍵碼值 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(); } // 第二次輸入延遲兩秒,刪除之前的數(shù)據(jù)重新計(jì)算 if(nextTime && lastTime && nextTime-lastTime>2000){code = String.fromCharCode(nextCode); }else{ code += String.fromCharCode(nextCode) } // 保存數(shù)據(jù) this.nextCode = nextCode; this.lastTime = nextTime; this.code = code; // 鍵入Enter if(e.which == 13) { // 判斷 code 長(zhǎng)度(這里就獲取到條碼值了,以下業(yè)務(wù)自由發(fā)揮) 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(’請(qǐng)輸入條碼’); } else{ this.$message(’條碼不合法:’ + code); } //鍵入回車務(wù)必清空code值 this.code = ’’ return false; } }}

總結(jié)

到此這篇關(guān)于js 獲取掃碼槍輸入數(shù)據(jù)的文章就介紹到這了,更多相關(guān)js 獲取掃碼槍輸入數(shù)據(jù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 伊人久久综合影院首页 | 亚洲一级高清在线中文字幕 | 一级特黄录像绵费播放 | 中国一级片免费看 | 亚洲六区| 国产综合第一页在线视频 | 国产高清区 | 91视频免费网址 | www91在线观看 | 色播影院性播12306影视 | 精品国产免费人成高清 | 性欧美成人免费观看视 | 国产黄色片在线看 | 香蕉97| 国产一区欧美二区 | 真实国产精品视频国产网 | 亚洲欧美中文日韩在线v日本 | 精品国产丝袜自在线拍国 | 久久国内| 激情毛片 | 2022av视频 | 国产一区二区三区四卡 | 欧美啪啪网址 | 欧美色视频日本片高清在线观看 | 亚洲欧美在线播放 | 亚洲精品一区二区三区四区手机版 | 欧美成人午夜免费完成 | 在线观看www日本免费网站 | 精品一区二区日本高清 | 香蕉视频免费看 | 久久国产精品2020免费m3u8 | 操出白浆视频 | 日韩精品永久免费播放平台 | 国产a v高清一区二区三区 | 久久精品图片 | 欧美高清在线精品一区二区不卡 | 国产乱在线观看视频 | 草草免费观看视频在线 | 日韩精品一区二区三区中文3d | 亚洲综合偷自成人网第页 | 久久成人免费 |