vue axios全局login

// main.js
const httpInstance = axios.create({
  baseURL: '/api'
})
//請求攔截
httpInstance.interceptors.request.use(config => {
  // if (!config.noShowLoading) { // 不顯示loading
  //   requestStore.updateUnderwayCount(1)
  // }
  if (config.params) {
    const encodeParam = {}

    Object.keys(config.params).forEach(key => {
      const p = config.params[key]
      if(key !== 'telList') {
        if (typeof p === 'object') {
          encodeParam[key] = p
          delete config.params[key]
        }
      }
    })
    config.params.encode = encodeParam
  }
  return config
})
//請求響應
httpInstance2.interceptors.response.use(res => {
  // if (!res.config.noShowLoading) { // 不顯示loading
  //   requestStore.updateUnderwayCount(-1)
  // }
  // debugger
  if (res.code === '302') {
    // 未登錄
    store.dispatch('popupTips', {
      text: '請先登陸',
      s: 1000,
      fn() {
        location.replace('/login?sourceurl=' +
          encodeURIComponent(location.href)
        )
      }
    })
  }
  res.getData = () => Promise.reject(res.data)
  return res
})

components/Login.vue

<template>
  <div v-show="requestCount" class="loadingAm">
    <div class="spinner">
      <div class="spinner-container container1">
        <div class="circle1"></div>
        <div class="circle2"></div>
        <div class="circle3"></div>
        <div class="circle4"></div>
      </div>
      <div class="spinner-container container2">
        <div class="circle1"></div>
        <div class="circle2"></div>
        <div class="circle3"></div>
        <div class="circle4"></div>
      </div>
      <div class="spinner-container container3">
        <div class="circle1"></div>
        <div class="circle2"></div>
        <div class="circle3"></div>
        <div class="circle4"></div>
      </div>
    </div>
  </div>
</template>
<script>
  export default{
    data(){
      return {
        requestCount: 0
      }
    },
    mounted(){
      const that = this
      that.$http.interceptors.request.use(config => {
        that.requestCount++
        return config
      }, function (error) {
        that.requestCount--
        return Promise.reject(error)
      })

      that.$http.interceptors.response.use(response => {
        that.requestCount--
        return response
      }, function (error) {
        that.requestCount--
        return Promise.reject(error)
      })
    }
  }
</script>

<style lang="scss">
  .loadingAm {
    position: fixed;
    left: 50%;
    top: 30%;
    margin-left: -60px;
    padding: 30px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 10px;
    z-index: 100;
  }

  .spinner {
    width: 40px;
    height: 40px;
    position: relative;;
  }

  .container1 > div, .container2 > div, .container3 > div {
    width: 12px;
    height: 12px;
    background-color: #FFF;

    border-radius: 100%;
    position: absolute;
    animation: bouncedelay 1.2s infinite ease-in-out;
    animation-fill-mode: both;
  }

  .spinner .spinner-container {
    position: absolute;
    width: 100%;
    height: 100%;
  }

  .container2 {
    transform: rotateZ(45deg);
  }

  .container3 {
    transform: rotateZ(90deg);
  }

  .circle1 {
    top: 0;
    left: 0;
  }

  .circle2 {
    top: 0;
    right: 0;
  }

  .circle3 {
    right: 0;
    bottom: 0;
  }

  .circle4 {
    left: 0;
    bottom: 0;
  }

  .container2 .circle1 {
    animation-delay: -1.1s;
  }

  .container3 .circle1 {
    animation-delay: -1.0s;
  }

  .container1 .circle2 {
    animation-delay: -0.9s;
  }

  .container2 .circle2 {
    animation-delay: -0.8s;
  }

  .container3 .circle2 {
    animation-delay: -0.7s;
  }

  .container1 .circle3 {
    animation-delay: -0.6s;
  }

  .container2 .circle3 {
    animation-delay: -0.5s;
  }

  .container3 .circle3 {
    animation-delay: -0.4s;
  }

  .container1 .circle4 {
    animation-delay: -0.3s;
  }

  .container2 .circle4 {
    animation-delay: -0.2s;
  }

  .container3 .circle4 {
    animation-delay: -0.1s;
  }

  @keyframes bouncedelay {
    0%, 80%, 100% {
      transform: scale(0.0);
    }
    40% {
      transform: scale(1.0);
    }
  }

</style>

或者使用element的也是同理,++ 或者 --

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章