vue項目element UI input框掃碼槍掃描過快出現(xiàn)數(shù)據(jù)丟失問題及解決方案
項目需求:
輸入框要掉兩個接口,根據(jù)第一個驗證接口返回的code,彈不同的框,點擊彈框確認再掉第二個接口


根據(jù)客戶現(xiàn)場反應,掃描槍快速掃描會出現(xiàn) 料號前幾位字符丟失 不完整的問題。于是開始了測試之路。
解決方案探索
1.首先考慮 ,可能是因為掃描過快,服務端接口還沒返回過來,輸入框就已經(jīng)清空了值 導致條碼有丟失字符的現(xiàn)象,所以我這邊做了一個緩存,將輸入框的值存到一個數(shù)組中去,定時上傳到接口。 【x】
2.考慮到可能是因為vue原因影響,就將element的 el-input,改為原生js Input框。【x】
3.輸入框加自動聚焦自定義指令,確保輸入完成輸入框不會失去焦點 【x】,因為el-input enter鍵觸發(fā)完成后,輸入框焦點還在。 【x】
4.最后分析,讓客戶給現(xiàn)場的服務器日志發(fā)送過來,查看前端傳到接口中的 條碼 是怎樣的一個缺失狀態(tài)。
通過查看 服務器日志,發(fā)現(xiàn)輸入框在調(diào)取第一個驗證接口時,條碼發(fā)送的是完整的 并沒有缺失,緊接著調(diào)取的第二個接口 條碼就出現(xiàn)了問題。
**第二個接口傳值時: 條碼會多出來幾位,導致第二次再去掃入,第二次的條碼會丟失幾位 **
查到問題 就好解決啦~
錯誤代碼:
this.barcode: 輸入框的值
verifyPutIn:輸入框第一次調(diào)用的 驗證接口

getInput():調(diào)用第二個接口的方法

問題就出在
第二個接口方法里,傳參的時候, code:this.barcode,code 是又從輸入框獲取了一次值,這個時候就會有問題。
因為掃碼槍在快速掃描的時候,速度很快,字符過長,頁面讀取速度會有些慢,這時候重新從輸入框獲取值,這個值并不是剛開始的輸入值了,可能會帶有第二次掃入的幾個字符。
所以服務器日志中看到的, 第二個接口傳過來的條碼號會多字符,第二次條碼號的前幾位 字符****會丟失 就是這個原因啦 !?。?/p>
解決方法
第二個接口調(diào)取時,code值 不要再從輸入框獲取,而是把第一個接口傳的輸入框值傳過來,給第二個接口用
完整代碼 如下
<el-input v-model="barcode" clearable size="small" placeholder="請掃描條碼編號" style="width: 200px" class="filter-item" @keyup.enter.native="toQuery()" />
<script>
export default {
data() {
return {
barcode:''
}
}
methods: {
toQuery() {
let verifyParam = {};
verifyParam = {
barcode: this.barcode,
name: this.pageOrderName,
};
this.barcode = null;
verifyPutIn(verifyParam).then((res) => {
if (res.code == 0) {
this.getInput(verifyParam.barcode);
} else {
this.$confirm(
res.msg, res.code == -1 ? "是否強制?庫?" : "強制?庫",
{
confirmButtonText: window.vm.$i18n.t("backTips.confirm"),
cancelButtonText: window.vm.$i18n.t("backTips.cancel"),
type: "warning",
}
).then(() => {
this.getInput(verifyParam.barcode);
});
}
});
},
getInput(codeStr) {
this.queryParams = {
code: codeStr,
name: this.pageOrderName,
};
operatePos(this.queryParams).then((res) => {
if (res.code == 0) {
this.name = "";
// 開啟自動播放
this.audio.autoplay = true;
this.audio.src = this.successUrl;
if (res.data) {
this.sonList = res.data;
this.getNumList(this.sonList);
this.poData = res.data.lastScanBoxCode.slice(
res.data.lastScanBoxCode.length - 1
);
this.boxName = res.data.currentRfid.slice(0, 2);
this.boxPartitionCounts = [];
for (let i = 0; i < res.data.boxPartitionCounts.length; i++) {
this.boxPartitionCounts.push({
latticeNumber: this.boxNoList[i],
amount: res.data.boxPartitionCounts[i],
});
}
this.resSize = res.data.platsize;
}
this.$infoMsg.showInfoMsg(res.msg, this);
} else {
// 開啟自動播放
this.audio.autoplay = true;
this.audio.src = this.errorUrl;
this.$infoMsg.showErrorMsg(res.msg, this);
}
});
},
}
</script>
到此這篇關于vue項目element UI input框掃碼槍掃描過快出現(xiàn)數(shù)據(jù)丟失問題的文章就介紹到這了,更多相關vue掃碼槍內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vite+vue3項目啟動報錯Unexpected?“%“問題及解決
這篇文章主要介紹了vite+vue3項目啟動報錯Unexpected?“%“問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
解決vue項目中某一頁面不想引用公共組件app.vue的問題
這篇文章主要介紹了解決vue項目中某一頁面不想引用公共組件app.vue的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
Echarts+VUE柱狀圖繪制細節(jié)并且屏幕自適應完整代碼
柱狀圖(或稱條形圖)是一種通過柱形的長度來表現(xiàn)數(shù)據(jù)大小的一種常用圖表類型,這篇文章主要給大家介紹了關于Echarts+VUE柱狀圖繪制細節(jié)并且屏幕自適應的相關資料,需要的朋友可以參考下2024-02-02

