第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

在ajax完成之前如何顯示加載指示器?

在ajax完成之前如何顯示加載指示器?

POPMUISE 2022-12-09 19:04:41
我想顯示一個(gè)加載微調(diào)器,直到我的消息加載完成。我在我的中實(shí)現(xiàn)了我的微調(diào)器Message.vue:import backend from '...'export default {  mounted: function() {    this.loadMessages();  },  methods: {    loadMessages() {      var self = this;      backend.getMessages().then(function(resp) {        self.previousDate = null;        self.messages = resp.data;        self.openLoader();      });    },    openLoader() {      let loader = this.$loading.show({        loader: 'spinner',        color: '#e32339',        canCancel: true,        container: this.$refs.loadingContainer      });      setTimeout(() => {        loader.hide()      }, 2500)    },  }}我的微調(diào)器在容器上顯示了 2500 毫秒,但我只是在模擬它而不知道 AJAX 請(qǐng)求何時(shí)完成。我完全不明白如何在 AJAX 請(qǐng)求完成之前顯示微調(diào)器?,F(xiàn)在它只顯示 2500 毫秒。我的backend.getMessages()方法是這樣的:import axios from 'axios'const host = /* process... */export default {  getMessages: function (peer) {    return axios.get(`${host}/api/messages`, {      params: {        me:      localStorage.getItem("user_id"),        device:  localStorage.getItem("device_id"),        peer: peer      }    })   },  //...}
查看完整描述

2 回答

?
海綿寶寶撒

TA貢獻(xiàn)1809條經(jīng)驗(yàn) 獲得超8個(gè)贊

加載程序應(yīng)在您的請(qǐng)求開始之前顯示。請(qǐng)注意,當(dāng)請(qǐng)求完成時(shí)axios.get()返回一個(gè)Promise解析,因此您可以使用Promise.prototype.finally關(guān)閉它Promise來隱藏加載程序:

mounted() {

  // show loader while fetching messages...

  const loader = this.$loading.show()


  backend.getMessages()

    .then(resp => /*...*/)

    .finally(() => loader.hide())

}

async這是用/await編寫它的另一種方法:


async mounted() {

  // show loader while fetching messages...

  const loader = this.$loading.show()


  try {

    const resp = await backend.getMessages()

    /*...*/


  } finally {

     loader.hide()

  }

}


查看完整回答
反對(duì) 回復(fù) 2022-12-09
?
ABOUTYOU

TA貢獻(xiàn)1812條經(jīng)驗(yàn) 獲得超5個(gè)贊

var loading在您的數(shù)據(jù)中添加一個(gè)。

展示<div v-if="loading">Spinner here</div>

然后

getMessages: function (peer) {

    this.loading = true; // AJAX request is loading

    return axios.get(`${host}/api/messages`, {

      params: {

        me:      localStorage.getItem("user_id"),

        device:  localStorage.getItem("device_id"),

        peer: peer

      }

    })

  },



loadMessages() {

      var self = this;

      backend.getMessages().then(function(resp) {

        self.previousDate = null;

        self.messages = resp.data;

        self.openLoader();

        self.loading = false // spinner disappear

      });

    },



查看完整回答
反對(duì) 回復(fù) 2022-12-09
  • 2 回答
  • 0 關(guān)注
  • 90 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)