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

vue實現(xiàn)在一個方法執(zhí)行完后執(zhí)行另一個方法的示例

 更新時間:2018年08月25日 15:36:37   作者:superlovelei  
今天小編就為大家分享一篇vue實現(xiàn)在一個方法執(zhí)行完后執(zhí)行另一個方法的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

用Promise來實現(xiàn)

function2(){
  // 你的邏輯代碼 
  return Promise.resolve(/* 這里是需要返回的數(shù)據(jù)*/)
}

function3(){
  // 你的邏輯代碼 
  return Promise.resolve(/* 這里是需要返回的數(shù)據(jù)*/)
}

// 調(diào)用
function1(){
  this.function2().then(val => { 
    this.function3();
  });
}

拓展知識:vue解決一個方法同時發(fā)送多個請求的問題

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

但是怎么解決這個問題呢?

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

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

在vue中,有一個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(){
   /*這里是請求的接口、參數(shù)以及回調(diào)函數(shù)等*/
  },
  postAction(){
   this.doPostAction()
  }
 },
 created(){
  this.doPostAction = _.debounce(this.sendAjax,500);
 }
}
</script>

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

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

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

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

以上這篇vue實現(xiàn)在一個方法執(zhí)行完后執(zhí)行另一個方法的示例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue中的ESLint配置方式

    Vue中的ESLint配置方式

    這篇文章主要介紹了Vue中的ESLint配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue-router路由傳參及隱藏參數(shù)問題

    vue-router路由傳參及隱藏參數(shù)問題

    這篇文章主要介紹了vue-router路由傳參及隱藏參數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue的click事件防抖和節(jié)流處理詳解

    Vue的click事件防抖和節(jié)流處理詳解

    今天小編就為大家分享一篇Vue的click事件防抖和節(jié)流處理詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue2.0 keep-alive最佳實踐

    vue2.0 keep-alive最佳實踐

    這篇文章主要為大家詳細(xì)介紹了vue2.0 keep-alive的最佳實踐,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • vue3自定義hooks/可組合函數(shù)方式

    vue3自定義hooks/可組合函數(shù)方式

    這篇文章主要介紹了vue3自定義hooks/可組合函數(shù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue代理如何配置重寫方法(pathRewrite與rewrite)

    vue代理如何配置重寫方法(pathRewrite與rewrite)

    這篇文章主要介紹了vue代理如何配置重寫方法(pathRewrite與rewrite),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue引入elementUi后打開頁面報錯Uncaught?TypeError的解決方式

    vue引入elementUi后打開頁面報錯Uncaught?TypeError的解決方式

    這篇文章主要給大家介紹了關(guān)于vue引入elementUi后打開頁面報錯Uncaught?TypeError:?Cannot?read?properties?of?undefined(reading?‘prototype‘)的解決方式,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • vue項目如何引入element?ui、iview和echarts

    vue項目如何引入element?ui、iview和echarts

    這篇文章主要介紹了vue項目如何引入element?ui、iview和echarts,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue3+Element?Plus使用svg加載iconfont的處理方法

    Vue3+Element?Plus使用svg加載iconfont的處理方法

    這篇文章主要介紹了Vue3+Element?Plus使用svg加載iconfont的解決方案,本文詳細(xì)介紹了如何在Element?Plus中使用iconfont,簡單的說就是要將其封裝成SVG,并且支持動態(tài)修改顏色,需要的朋友可以參考下
    2022-08-08
  • 詳解如何使用Vue2做服務(wù)端渲染

    詳解如何使用Vue2做服務(wù)端渲染

    本篇文章主要介紹了如何使用Vue2做服務(wù)端渲染 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03

最新評論