亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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

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

POPMUISE 2022-12-09 19:04:41
我想顯示一個加載微調器,直到我的消息加載完成。我在我的中實現了我的微調器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)    },  }}我的微調器在容器上顯示了 2500 毫秒,但我只是在模擬它而不知道 AJAX 請求何時完成。我完全不明白如何在 AJAX 請求完成之前顯示微調器。現在它只顯示 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貢獻1809條經驗 獲得超8個贊

加載程序應在您的請求開始之前顯示。請注意,當請求完成時axios.get()返回一個Promise解析,因此您可以使用Promise.prototype.finally關閉它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()

  }

}


查看完整回答
反對 回復 2022-12-09
?
ABOUTYOU

TA貢獻1812條經驗 獲得超5個贊

var loading在您的數據中添加一個。

展示<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

      });

    },



查看完整回答
反對 回復 2022-12-09
  • 2 回答
  • 0 關注
  • 84 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號