jQuery監聽掃碼槍禁止手動輸入的實作方法
本文主要和大家 分享基於jQuery的掃碼槍監聽。如果只是想實現監聽獲取條碼掃碼信息,可以直接拿來使用,如果有更多的條碼判斷處理邏輯需要自己擴展哦,希望能幫助到大家。
一、功能需求
使用掃碼槍掃描條碼,在一個web頁面監聽取得掃碼槍的數據,並禁止使用者進行手動的輸入操作。
開始的想法非常簡單,因為掃碼槍就是模擬鍵盤的輸入,當他用usb介面插入電腦的時候,就變成了一個外接的輸入設備,用js監聽就可以了。但是如何判斷使用者是否為手動輸入就需要做一些處理了。
二、主要問題
1.如何判斷是否手動輸入
2.如何判斷一個條碼輸入完成
三、解決方案
手動輸入的解決方法是:對比一個鍵從按下到抬起的時間間隔,以及兩次按鍵的時間間隔。
因為掃碼槍的輸入速度非常的快,我測試的掃碼槍輸入的間隔大概在15-60毫秒,然後手動輸入的100-200之間,除非刻意的想突破限制進行快速的輸入。這個間隔值可以控制的很小,前提不要快過掃碼搶的速度。
輸入完成的判斷:可以對輸入框變化做一個監聽,如果達到我們想要的位數,則提交伺服器端進行處理;第二種是基於掃碼槍,因為我使用的掃碼槍可以配置掃碼成功最後附加一個回車。所以根據回車的keycode就可以判斷為輸入已經結束,然後取得輸入框的value,再進行後續的處理(提交伺服器等)。
四、程式碼
時間間隔的判斷,依賴jQuery的三個事件:keydown,keypress,keyup;即鍵開始按下,已經按下,彈起這三個狀態,keydown,就是在按鍵剛被按下,但鍵值還沒有寫入文字框,keypress已經按下並且值已經輸入到文字框,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中的範例,引入相關的js:
<input id="barCode" value="" type="text" placeholder="stay focus" style="" name=""> $("#barCode").startListen({ barcodeLen : 10, letter : true, number : true, show : function(code){ layer.msg(code); } });
這裡可設定的參數:包含條碼的長度,是否包含英文字母,是否包含數字。以及一個show回調方法,這個方法會在掃碼成功,條碼合法的情況下被調用,返回條碼的值,以便做自定義的操作,如上傳伺服器等。
程式碼中對頁面的輸入框做了stay focus,所以頁面有其他的輸入需求無法實現,可以除去keepFocusInput的呼叫。
相關推薦:
jquery監聽div內容的變化具體實現想法_ jquery
jQuery監控文字方塊事件並作對應處理的方法_jquery
以上是jQuery監聽掃碼槍禁止手動輸入的實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

jQuery引用方法詳解:快速上手指南jQuery是一個受歡迎的JavaScript庫,被廣泛用於網站開發中,它簡化了JavaScript編程,並為開發者提供了豐富的功能和特性。本文將詳細介紹jQuery的引用方法,並提供具體的程式碼範例,幫助讀者快速上手。引入jQuery首先,我們需要在HTML檔案中引入jQuery函式庫。可以透過CDN連結的方式引入,也可以下載

jQuery中如何使用PUT請求方式?在jQuery中,發送PUT請求的方法與發送其他類型的請求類似,但需要注意一些細節和參數設定。 PUT請求通常用於更新資源,例如更新資料庫中的資料或更新伺服器上的檔案。以下是在jQuery中使用PUT請求方式的具體程式碼範例。首先,確保引入了jQuery庫文件,然後可以透過以下方式發送PUT請求:$.ajax({u

標題:jQuery小技巧:快速修改頁面所有a標籤的文字在網頁開發中,我們經常需要對頁面中的元素進行修改和操作。使用jQuery時,有時候需要一次修改頁面中所有a標籤的文字內容,這樣可以節省時間和精力。以下將介紹如何使用jQuery快速修改頁面所有a標籤的文本,同時給出具體的程式碼範例。首先,我們需要引入jQuery庫文件,確保在頁面中引入了以下程式碼:<

標題:使用jQuery修改所有a標籤的文字內容jQuery是一款受歡迎的JavaScript庫,被廣泛用於處理DOM操作。在網頁開發中,經常會遇到需要修改頁面上連結標籤(a標籤)的文字內容的需求。本文將介紹如何使用jQuery來實現這個目標,並提供具體的程式碼範例。首先,我們需要在頁面中引入jQuery庫。在HTML檔案中加入以下程式碼:

jQuery如何移除元素的height屬性?在前端開發中,經常會遇到需要操作元素的高度屬性的需求。有時候,我們可能需要動態改變元素的高度,而有時候又需要移除元素的高度屬性。本文將介紹如何使用jQuery來移除元素的高度屬性,並提供具體的程式碼範例。在使用jQuery操作高度屬性之前,我們首先需要了解CSS中的height屬性。 height屬性用於設定元素的高度

jQuery是一種流行的JavaScript庫,被廣泛用於處理網頁中的DOM操作和事件處理。在jQuery中,eq()方法是用來選擇指定索引位置的元素的方法,具體使用方法和應用場景如下。在jQuery中,eq()方法選擇指定索引位置的元素。索引位置從0開始計數,即第一個元素的索引是0,第二個元素的索引是1,依此類推。 eq()方法的語法如下:$("s

jQuery是一個受歡迎的JavaScript函式庫,廣泛用於網頁開發。在網頁開發過程中,經常需要透過JavaScript動態地在表格中新增一行。本文將介紹如何使用jQuery為表格新增一行,並提供具體的程式碼範例。首先,我們需要在HTML頁面中引入jQuery函式庫。可以透過以下程式碼在標籤中引入jQuery庫:

如何判斷jQuery元素是否具有特定屬性?在使用jQuery操作DOM元素時,常會遇到需要判斷元素是否具有某個特定屬性的情況。在這種情況下,我們可以藉助jQuery提供的方法來輕鬆實現這項功能。以下將介紹兩種常用的方法來判斷一個jQuery元素是否具有特定屬性,並附上具體的程式碼範例。方法一:使用attr()方法和typeof運算子//判斷元素是否具有特定屬
