欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項(xiàng)目element UI input框掃碼槍掃描過(guò)快出現(xiàn)數(shù)據(jù)丟失問(wèn)題及解決方案

 更新時(shí)間:2022年12月06日 10:39:53   作者:藍(lán)胖子的多啦A夢(mèng)  
這篇文章主要介紹了vue項(xiàng)目element UI input框掃碼槍掃描過(guò)快出現(xiàn)數(shù)據(jù)丟失問(wèn)題,輸入框要掉兩個(gè)接口,根據(jù)第一個(gè)驗(yàn)證接口返回的code,彈不同的框,點(diǎn)擊彈框確認(rèn)再掉第二個(gè)接口,需要的朋友可以參考下

項(xiàng)目需求:

輸入框要掉兩個(gè)接口,根據(jù)第一個(gè)驗(yàn)證接口返回的code,彈不同的框,點(diǎn)擊彈框確認(rèn)再掉第二個(gè)接口

根據(jù)客戶現(xiàn)場(chǎng)反應(yīng),掃描槍快速掃描會(huì)出現(xiàn) 料號(hào)前幾位字符丟失 不完整的問(wèn)題。于是開(kāi)始了測(cè)試之路。

解決方案探索

1.首先考慮 ,可能是因?yàn)閽呙柽^(guò)快,服務(wù)端接口還沒(méi)返回過(guò)來(lái),輸入框就已經(jīng)清空了值 導(dǎo)致條碼有丟失字符的現(xiàn)象,所以我這邊做了一個(gè)緩存,將輸入框的值存到一個(gè)數(shù)組中去,定時(shí)上傳到接口。 【x】
2.考慮到可能是因?yàn)関ue原因影響,就將element的 el-input,改為原生js Input框。【x】
3.輸入框加自動(dòng)聚焦自定義指令,確保輸入完成輸入框不會(huì)失去焦點(diǎn) 【x】,因?yàn)閑l-input enter鍵觸發(fā)完成后,輸入框焦點(diǎn)還在。 【x】

4.最后分析,讓客戶給現(xiàn)場(chǎng)的服務(wù)器日志發(fā)送過(guò)來(lái),查看前端傳到接口中的 條碼 是怎樣的一個(gè)缺失狀態(tài)。
通過(guò)查看 服務(wù)器日志,發(fā)現(xiàn)輸入框在調(diào)取第一個(gè)驗(yàn)證接口時(shí),條碼發(fā)送的是完整的 并沒(méi)有缺失,緊接著調(diào)取的第二個(gè)接口 條碼就出現(xiàn)了問(wèn)題。

**第二個(gè)接口傳值時(shí): 條碼會(huì)多出來(lái)幾位,導(dǎo)致第二次再去掃入,第二次的條碼會(huì)丟失幾位 **

查到問(wèn)題 就好解決啦~

錯(cuò)誤代碼:

this.barcode: 輸入框的值

verifyPutIn:輸入框第一次調(diào)用的 驗(yàn)證接口

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

問(wèn)題就出在

第二個(gè)接口方法里,傳參的時(shí)候, code:this.barcode,code 是又從輸入框獲取了一次值,這個(gè)時(shí)候就會(huì)有問(wèn)題。
因?yàn)閽叽a槍在快速掃描的時(shí)候,速度很快,字符過(guò)長(zhǎng),頁(yè)面讀取速度會(huì)有些慢,這時(shí)候重新從輸入框獲取值,這個(gè)值并不是剛開(kāi)始的輸入值了,可能會(huì)帶有第二次掃入的幾個(gè)字符。

所以服務(wù)器日志中看到的, 第二個(gè)接口傳過(guò)來(lái)的條碼號(hào)會(huì)多字符,第二次條碼號(hào)的前幾位 字符****會(huì)丟失 就是這個(gè)原因啦 ?。。?/p>

解決方法

第二個(gè)接口調(diào)取時(shí),code值 不要再?gòu)妮斎肟颢@取,而是把第一個(gè)接口傳的輸入框值傳過(guò)來(lái),給第二個(gè)接口用

完整代碼 如下

<el-input  v-model="barcode" clearable size="small" placeholder="請(qǐng)掃描條碼編號(hào)" 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 ? "是否強(qiáng)制?庫(kù)?" : "強(qiáng)制?庫(kù)",
            {
              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 = "";
          // 開(kāi)啟自動(dòng)播放
          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 {
          // 開(kāi)啟自動(dòng)播放
          this.audio.autoplay = true;
          this.audio.src = this.errorUrl;
          this.$infoMsg.showErrorMsg(res.msg, this);
        }
      });
    }, 
 }
  </script>

到此這篇關(guān)于vue項(xiàng)目element UI input框掃碼槍掃描過(guò)快出現(xiàn)數(shù)據(jù)丟失問(wèn)題的文章就介紹到這了,更多相關(guān)vue掃碼槍內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue.Draggable實(shí)現(xiàn)拖拽效果

    Vue.Draggable實(shí)現(xiàn)拖拽效果

    這篇文章主要介紹了Vue.Draggable實(shí)現(xiàn)拖拽效果,使用簡(jiǎn)單方便 ,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Vue自定義組件中v-model的使用方法示例

    Vue自定義組件中v-model的使用方法示例

    日常開(kāi)發(fā)中除了直接在input標(biāo)簽上使用v-model指令外,封裝的組件也需要v-model,下面這篇文章主要給大家介紹了關(guān)于Vue自定義組件中v-model使用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • vite+vue3項(xiàng)目啟動(dòng)報(bào)錯(cuò)Unexpected?“%“問(wèn)題及解決

    vite+vue3項(xiàng)目啟動(dòng)報(bào)錯(cuò)Unexpected?“%“問(wèn)題及解決

    這篇文章主要介紹了vite+vue3項(xiàng)目啟動(dòng)報(bào)錯(cuò)Unexpected?“%“問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫(huà)效果實(shí)例詳解

    Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫(huà)效果實(shí)例詳解

    最近在寫(xiě)vue的一個(gè)項(xiàng)目要實(shí)現(xiàn)過(guò)渡的效果,雖然vue動(dòng)畫(huà)不是強(qiáng)項(xiàng),庫(kù)也多,但是基本的坑還是得踩扎實(shí),下面這篇文章主要給大家介紹了關(guān)于Vue中實(shí)現(xiàn)過(guò)渡動(dòng)畫(huà)效果的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • 解決vue項(xiàng)目中某一頁(yè)面不想引用公共組件app.vue的問(wèn)題

    解決vue項(xiàng)目中某一頁(yè)面不想引用公共組件app.vue的問(wèn)題

    這篇文章主要介紹了解決vue項(xiàng)目中某一頁(yè)面不想引用公共組件app.vue的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)完整代碼

    Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)完整代碼

    柱狀圖(或稱條形圖)是一種通過(guò)柱形的長(zhǎng)度來(lái)表現(xiàn)數(shù)據(jù)大小的一種常用圖表類(lèi)型,這篇文章主要給大家介紹了關(guān)于Echarts+VUE柱狀圖繪制細(xì)節(jié)并且屏幕自適應(yīng)的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡

    vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡

    放大鏡在很多地方都可以使用的到,本文主要介紹了vue結(jié)合leaflet實(shí)現(xiàn)地圖放大鏡,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • vue3+vite+ts之a(chǎn)xios的坑及解決

    vue3+vite+ts之a(chǎn)xios的坑及解決

    這篇文章主要介紹了vue3+vite+ts之a(chǎn)xios的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 命令行CLI一鍵生成各種煩人的lint配置實(shí)例

    命令行CLI一鍵生成各種煩人的lint配置實(shí)例

    這篇文章主要為大家介紹了命令行CLI一鍵生成各種煩人的lint配置實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • vue使用swiper.js重疊輪播組建樣式

    vue使用swiper.js重疊輪播組建樣式

    這篇文章主要為大家詳細(xì)介紹了vue使用swiper.js重疊輪播組建樣式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評(píng)論