国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

vue2實現數據請求顯示loading圖

來源:懂視網 責編:小采 時間:2020-11-27 22:24:57
文檔

vue2實現數據請求顯示loading圖

vue2實現數據請求顯示loading圖:一般項目中,有時候會要求,你在數據請求的時候顯示一張gif圖片,然后數據加載完后,消失。這個,一般只需要在封裝的axios中寫入js事件即可。當然,我們首先需要在app.vue中,加入此圖片。如下: <template> <div id=app>
推薦度:
導讀vue2實現數據請求顯示loading圖:一般項目中,有時候會要求,你在數據請求的時候顯示一張gif圖片,然后數據加載完后,消失。這個,一般只需要在封裝的axios中寫入js事件即可。當然,我們首先需要在app.vue中,加入此圖片。如下: <template> <div id=app>

一般項目中,有時候會要求,你在數據請求的時候顯示一張gif圖片,然后數據加載完后,消失。這個,一般只需要在封裝的axios中寫入js事件即可。當然,我們首先需要在app.vue中,加入此圖片。如下:

<template>
 <div id="app">
 <loading v-show="fetchLoading"></loading>
 <router-view></router-view>
 </div>
</template>

<script>
 import { mapGetters } from 'vuex';
 import Loading from './components/common/loading';

 export default {
 name: 'app',
 data() {
 return {
 }
 },
 computed: {
 ...mapGetters([
 'fetchLoading',
 ]),
 },
 components: {
 Loading,
 }
 }
</script>

<style>
 #app{
 width: 100%;
 height: 100%;
 }
</style>

這里的fetchLoading是存在vuex里面的一個變量。在store/modules/common.js里需要如下定義:

/* 此js文件用于存儲公用的vuex狀態 */
import api from './../../fetch/api'
import * as types from './../types.js'
const state = {
 // 請求數據時加載狀態loading
 fetchLoading: false
}
const getters = {
 // 請求數據時加載狀態
 fetchLoading: state => state.fetchLoading
}
const actions = {
 // 請求數據時狀態loading
 FETCH_LOADING({
 commit
 }, res) {
 commit(types.FETCH_LOADING, res)
 },
}
const mutations = {
 // 請求數據時loading
 [types.FETCH_LOADING] (state, res) {
 state.fetchLoading = res
 }
}

loading組件如下:

<template>
 <div class="loading">
 <img src="./../../assets/main/running.gif" alt="">
 </div>
</template>

<script>
 export default {
 name: 'loading',
 data () {
 return {}
 },
 }
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
 .loading{
 position: fixed;
 top:0;
 left:0;
 z-index:121;
 width: 100%;
 height: 100%;
 background: rgba(0,0,0,0.3);
 display: table-cell;
 vertical-align: middle;
 text-align: center;
 }
 .loading img{
 margin:5rem auto;
 }
</style>

最后在fetch/api.js里封裝的axios里寫入判斷loading事件即可:如下

// axios的請求時間
let axiosDate = new Date()
export function fetch (url, params) {
 return new Promise((resolve, reject) => {
 axios.post(url, params)
 .then(response => {
 // 關閉 loading圖片消失
 let oDate = new Date()
 let time = oDate.getTime() - axiosDate.getTime()
 if (time < 500) time = 500
 setTimeout(() => {
 store.dispatch('FETCH_LOADING', false)
 }, time)
 resolve(response.data)
 })
 .catch((error) => {
 // 關閉 loading圖片消失
 store.dispatch('FETCH_LOADING', false)
 axiosDate = new Date()
 reject(error)
 })
 })
}
export default {
 // 組件中公共頁面請求函數
 commonApi (url, params) {
 if(stringQuery(window.location.href)) {
 store.dispatch('FETCH_LOADING', true);
 }
 axiosDate = new Date();
 return fetch(url, params);
 }
}

這樣就實現了,項目中當加載數據的時候,顯示gif圖片,當數據加載出來時消失。

關于vue.js的學習教程,請大家點擊專題vue.js組件學習教程、Vue.js前端組件學習教程進行學習。

更多vue學習教程請閱讀專題《vue實戰教程》

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

vue2實現數據請求顯示loading圖

vue2實現數據請求顯示loading圖:一般項目中,有時候會要求,你在數據請求的時候顯示一張gif圖片,然后數據加載完后,消失。這個,一般只需要在封裝的axios中寫入js事件即可。當然,我們首先需要在app.vue中,加入此圖片。如下: <template> <div id=app>
推薦度:
標簽: 圖片 VUE 數據請求
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 色婷婷国产| 国产日产欧美精品一区二区三区 | 欧美一级色图 | 日本高清一区二区三区不卡免费 | 国产原创一区二区 | 五月天婷婷在线观看 | 欧美日本道免费二区三区 | 亚洲韩国日本欧美一区二区三区 | 欧美阿v | 日韩另类在线 | 欧美一区二区在线免费观看 | 国产欧美一区二区三区视频 | 一本一本久久α久久精品66 | 欧美国产日韩在线播放 | 亚洲一区二区三区91 | 国产日韩在线观看视频网站 | 色综合天天综合中文网 | 欧美日韩国内 | 欧美一级成人影院免费的 | 中文字幕 在线观看 | 日韩欧美一卡二区 | 欧美亚洲国产一区二区 | 亚欧成人毛片一区二区三区四区 | 天堂va欧美ⅴa亚洲va一国产 | 久久精品成人一区二区三区 | 成人午夜精品久久久久久久小说 | 任你躁欧美一级在线精品免费 | 欧美在线一区二区三区不卡 | 欧美中出在线 | 日韩综合第一页 | 日本在线不卡一区二区 | 成人a毛片免费视频观看 | 久久久久久国产精品免费 | 精品国产综合成人亚洲区 | 一级一级一级毛片免费毛片 | 日本高清一二三区 | 日韩国产综合 | 国产精品视频一区二区三区不卡 | 国产不卡网 | 二区在线播放 | 国产日韩欧美视频在线观看 |