亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue解決一個(gè)方法同時(shí)發(fā)送多個(gè)請(qǐng)求的問題

 更新時(shí)間:2018年09月25日 14:14:35   作者:狂野的心跳  
今天小編就為大家分享一篇vue解決一個(gè)方法同時(shí)發(fā)送多個(gè)請(qǐng)求的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

在項(xiàng)目開發(fā)過程中,讓人抓狂之一的問題就是一個(gè)點(diǎn)擊事件,當(dāng)快速點(diǎn)擊的時(shí)候,它會(huì)重復(fù)發(fā)送多個(gè)請(qǐng)求。這是不允許出現(xiàn)的。

但是怎么解決這個(gè)問題呢?

一般處理方法,就是點(diǎn)擊的時(shí)候,立刻將該按鈕disabled,這樣就可以避免重復(fù)發(fā)送請(qǐng)求了。但是我發(fā)現(xiàn)這個(gè)有一個(gè)弊端,那就是:

如果,該事件有許多的驗(yàn)證,比如電話、郵箱格式是否正確呀,必填的是否填了呀等等。一旦你點(diǎn)擊就把按鈕disabled了,發(fā)現(xiàn)該填的沒填,回去填完后發(fā)現(xiàn)按鈕不能點(diǎn)了?那是因?yàn)閯偛劈c(diǎn)擊的時(shí)候被你disabled了,所以還得在驗(yàn)證的方法中取消按鈕的disable。就造成了你點(diǎn)擊的時(shí)候,第一步,將按鈕disable了,然后一步一步向下驗(yàn)證,如果驗(yàn)證出錯(cuò),得取消disable,當(dāng)所有驗(yàn)證通過了,在請(qǐng)求的回調(diào)函數(shù)中,成功了也要取消disable,失敗了也要取消disable,因?yàn)槭×擞脩舳喟脒€會(huì)繼續(xù)點(diǎn)兩次,不取消disable會(huì)讓用戶發(fā)現(xiàn)怎么點(diǎn)不了了。這就造成了全篇都是按鈕disable的設(shè)置與取消。一旦有修改,很難維護(hù)的。

在vue中,有一個(gè)lodash,我們只需引入就可以使用了。比如以下代碼:

<template>
 <div>
 <div class="bindBtn">
  <button class="bindDataBtn" @click="postAction">提交</button>
 </div>
 </div>
</template>
<script>
import _ from 'lodash'
export default {
 data() {
 return {
 
 }
 },
 mounted() {
 
 },
 methods: {
 sendAjax(){
  /*這里是請(qǐng)求的接口、參數(shù)以及回調(diào)函數(shù)等*/
 },
 postAction(){
  this.doPostAction()
 }
 },
 created(){
 this.doPostAction = _.debounce(this.sendAjax,500);
 }
}
</script>

我們首先將發(fā)送請(qǐng)求的ajax方法寫在一個(gè)函數(shù)里面,在這里就是sendAjax函數(shù),其次,我們引入lodash,然后將sendAjax這個(gè)函數(shù)用一個(gè)方法自定義一下,在這里就是doPostAction,其中_是我們引入的lodash,_.debounce是一個(gè)限制操作頻率的函數(shù),里面的是500是毫秒單位。

當(dāng)執(zhí)行點(diǎn)擊事件的時(shí)候,也就是postAction函數(shù),我們只需要調(diào)用doPostAction這個(gè)函數(shù)就可以了,而那個(gè)500的功能就是你在這個(gè)時(shí)間段里,無論執(zhí)行了多少次這個(gè)點(diǎn)擊事件,它都只會(huì)執(zhí)行一次。

這樣就少了我們通篇disable來disable去

最后附上官網(wǎng)例子:點(diǎn)擊前往

以上這篇vue解決一個(gè)方法同時(shí)發(fā)送多個(gè)請(qǐng)求的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue?前端路由工作原理hash與history的區(qū)別

    Vue?前端路由工作原理hash與history的區(qū)別

    這篇文章主要介紹了Vue?前端路由工作原理hash與history的區(qū)別,文章圍繞主題展開vue-router的工作原理的簡(jiǎn)單介紹,感興趣的朋友可以學(xué)習(xí)一下
    2022-07-07
  • 關(guān)于vite.config.ts文件的配置方式

    關(guān)于vite.config.ts文件的配置方式

    這篇文章主要介紹了關(guān)于vite.config.ts文件的配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 簡(jiǎn)單理解vue中實(shí)例屬性vm.$els

    簡(jiǎn)單理解vue中實(shí)例屬性vm.$els

    這篇文章主要幫助大家簡(jiǎn)單理解vue中實(shí)例屬性vm.$els,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Vue.js頁面中有多個(gè)input搜索框如何實(shí)現(xiàn)防抖操作

    Vue.js頁面中有多個(gè)input搜索框如何實(shí)現(xiàn)防抖操作

    debounce是lodash工具庫中的一個(gè)非常好用的函數(shù)。這篇文章主要介紹了Vue.js頁面中有多個(gè)input搜索框如何實(shí)現(xiàn)防抖操作,需要的朋友可以參考下
    2019-11-11
  • 詳解Vue基于 Nuxt.js 實(shí)現(xiàn)服務(wù)端渲染(SSR)

    詳解Vue基于 Nuxt.js 實(shí)現(xiàn)服務(wù)端渲染(SSR)

    直接使用 Vue 構(gòu)建前端單頁面應(yīng)用,頁面源碼時(shí)只有簡(jiǎn)單的幾行 html,這并不利于網(wǎng)站的 SEO,這時(shí)候就需要服務(wù)端渲染,本篇文章主要介紹了詳解Vue基于 Nuxt.js 實(shí)現(xiàn)服務(wù)端渲染(SSR),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • vue文件代碼縮進(jìn)以及格式化代碼方式[自定義]

    vue文件代碼縮進(jìn)以及格式化代碼方式[自定義]

    這篇文章主要介紹了vue文件代碼縮進(jìn)以及格式化代碼方式[自定義],具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue微信分享插件使用方法詳解

    vue微信分享插件使用方法詳解

    這篇文章主要介為大家詳細(xì)紹了vue微信分享插件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 淺談vue的第一個(gè)commit分析

    淺談vue的第一個(gè)commit分析

    這篇文章主要介紹了淺談vue的第一個(gè)commit分析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 淺談vue中computed屬性對(duì)data屬性賦值為undefined的原因

    淺談vue中computed屬性對(duì)data屬性賦值為undefined的原因

    本文主要介紹了淺談vue中computed屬性對(duì)data屬性賦值為undefined的原因,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • vue小圖標(biāo)favicon不顯示的解決方案

    vue小圖標(biāo)favicon不顯示的解決方案

    本篇文章主要介紹了vue小圖標(biāo)favicon不顯示的解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09

最新評(píng)論