摘要:一功能需求使用掃碼槍掃描條碼,在一個頁面監(jiān)聽獲取掃碼槍的數(shù)據(jù),并禁止用戶進(jìn)行手動的輸入操作。因為掃碼槍的輸入速度非常的快,我測試的掃碼槍輸入的間隔大概在毫秒,然后手動輸入的之間,除非刻意的想突破限制進(jìn)行快速的輸入。
基于jQuery的掃碼槍監(jiān)聽。如果只是想實現(xiàn)監(jiān)聽獲取條碼掃碼信息,可以直接拿來使用,如果有更多的條碼判斷處理邏輯需要自己擴展。
一、功能需求
使用掃碼槍掃描條碼,在一個web頁面監(jiān)聽獲取掃碼槍的數(shù)據(jù),并禁止用戶進(jìn)行手動的輸入操作。
開始的想法非常簡單,因為掃碼槍就是模擬鍵盤的輸入,當(dāng)他用usb接口插入電腦的時候,就變成了一個外接的輸入設(shè)備,用js監(jiān)聽就可以了。但是如何判斷用戶是否為手動輸入就需要做一些處理了。
二、主要問題
1.如何判斷是否手動輸入
2.如何判斷一個條碼輸入完成
三、解決方案
手動輸入的解決辦法就是:對比一個鍵從按下到抬起的時間間隔,以及兩次按鍵的時間間隔。
因為掃碼槍的輸入速度非常的快,我測試的掃碼槍輸入的間隔大概在15-60毫秒,然后手動輸入的100-200之間,除非刻意的想突破限制進(jìn)行快速的輸入。這個間隔值可以控制的很小,前提不要快過掃碼搶的速度。
輸入完成的判斷:可以對輸入框變化做一個監(jiān)聽,如果達(dá)到我們想要的位數(shù),則提交服務(wù)器端進(jìn)行處理;第二種是基于掃碼槍,因為我使用的掃碼槍可以配置掃碼成功最后附加一個回車。所以根據(jù)回車的keycode就可以判斷為輸入已經(jīng)結(jié)束,然后獲取輸入框的value,再進(jìn)行后續(xù)的處理(提交服務(wù)器等)。
四、代碼
時間間隔的判斷,依賴于jQuery的三個事件:keydown,keypress,keyup;即鍵開始按下,已經(jīng)按下,彈起這三個狀態(tài),keydown,就是在按鍵剛剛被按下,但鍵值還沒有寫入文本框,keypress已經(jīng)按下并且值已經(jīng)輸入到文本框,keyup就是彈起了。
需要做判斷的就是按鍵從按下到抬起的時間間隔,與兩次keydown的時間間隔。
主要的手動輸入判斷代碼。
var barcode = { listenerObj: null, oneKeyTime : "", /* 一次按鍵時間間隔 */ twoKeyTime : "", /* 兩次按鍵時間間隔 */ keyDownTime: "", /* 鍵按下的時間 */ barcodeLen : 8 , /* 條形碼長度 */ spanTime : 70, /* 一次按鍵按下到釋放的時間間隔 */ on_key_down : function (){ var that = this; this.listenerObj.keydown(function(e){ if(e.which !== 13 && !(that.in_range(e.which))){ $(that.listenerObj).val(""); return ; } var d = new Date(); var curTime = parseInt(d.getTime()); if(that.keyDownTime !== "" && that.keyDownTime !== NaN){ that.twoKeyTime = curTime - that.keyDownTime; } that.keyDownTime = curTime; }); }, on_key_up : function(){ var that = this; this.listenerObj.keyup(function(e){ var d = new Date(); var keyUpTime = d.getTime(); that.oneKeyTime = parseInt(keyUpTime) - parseInt(that.keyDownTime); var isHand = that.checkHandInput(); if(isHand && that.in_range(e.which)){ layer.msg("禁止手動輸入"); $(that.listenerObj).val(""); } }) }, on_key_press : function(){ var that = this; this.listenerObj.keypress(function(e){ if(e.which == 13 && that.check_barcode()){ that.createListEl(); } }); }, checkHandInput : function(){ if((this.oneKeyTime > this.spanTime) || this.twoKeyTime > this.spanTime){ return true; }else{ return false; } }, }
將代碼整理了一下,放到了Github。
我的js代碼中的提示用到了layer.js,所以如果使用按照index.html中的示例,引入相關(guān)的js:
$("#barCode").startListen({ barcodeLen : 10, letter : true, number : true, show : function(code){ layer.msg(code); } });
這里可配置的參數(shù):包括條碼的長度,是否包含英文字母,是否包含數(shù)字。以及一個show回調(diào)方法,這個方法會在掃碼成功,條碼合法的情況下被調(diào)用,返回條碼的值,以便做自定義的操作,如上傳服務(wù)器等。
代碼中對頁面的輸入框做了stay focus,所以頁面有其他的輸入需求無法實現(xiàn),可以除去keepFocusInput的調(diào)用。
代碼很簡單,可以直接閱讀,有值得改進(jìn)的地方歡迎指出。
推薦一款適合二次開發(fā)的掃描槍:MS3398迷你條碼掃描槍
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/50953.html
摘要:一功能需求使用掃碼槍掃描條碼,在一個頁面監(jiān)聽獲取掃碼槍的數(shù)據(jù),并禁止用戶進(jìn)行手動的輸入操作。因為掃碼槍的輸入速度非常的快,我測試的掃碼槍輸入的間隔大概在毫秒,然后手動輸入的之間,除非刻意的想突破限制進(jìn)行快速的輸入。 基于jQuery的掃碼槍監(jiān)聽。如果只是想實現(xiàn)監(jiān)聽獲取條碼掃碼信息,可以直接拿來使用,如果有更多的條碼判斷處理邏輯需要自己擴展。一、功能需求 使用掃碼槍掃描條碼,在一個web...
摘要:一功能需求使用掃碼槍掃描條碼,在一個頁面監(jiān)聽獲取掃碼槍的數(shù)據(jù),并禁止用戶進(jìn)行手動的輸入操作。因為掃碼槍的輸入速度非常的快,我測試的掃碼槍輸入的間隔大概在毫秒,然后手動輸入的之間,除非刻意的想突破限制進(jìn)行快速的輸入。 基于jQuery的掃碼槍監(jiān)聽。如果只是想實現(xiàn)監(jiān)聽獲取條碼掃碼信息,可以直接拿來使用,如果有更多的條碼判斷處理邏輯需要自己擴展。一、功能需求 使用掃碼槍掃描條碼,在一個web...
摘要:一開始的時候,定義焦點在文本框,當(dāng)文本框失去焦點的時候重新定焦在文本框。這樣,就無法判斷,焦點是否在文本框。于是我想到了用定時器來做,代碼如下定時器每隔檢查一次,當(dāng)發(fā)現(xiàn)焦點不在文本框里,則定焦到最初的文本框,否則不改變焦點。 沒耐心的朋友,可以直接看代碼。 最近在做一個關(guān)于收銀臺的項目,其中有一個需求,是掃碼槍掃描支付碼進(jìn)行支付。掃碼槍觸發(fā)的事件,其實是一個keyup enter事件,...
閱讀 1561·2021-11-25 09:43
閱讀 2348·2019-08-30 15:55
閱讀 1472·2019-08-30 13:08
閱讀 2684·2019-08-29 10:59
閱讀 823·2019-08-29 10:54
閱讀 1595·2019-08-26 18:26
閱讀 2555·2019-08-26 13:44
閱讀 2659·2019-08-23 18:36