亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue手寫加載動(dòng)畫項(xiàng)目

 更新時(shí)間:2021年10月21日 17:04:30   作者:海綿寶寶y  
這篇文章主要為大家詳細(xì)介紹了vue手寫加載動(dòng)畫項(xiàng)目,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

在頁(yè)面沒(méi)有響應(yīng)時(shí),展示加載動(dòng)畫是一種對(duì)用戶友好的表現(xiàn),不至于白屏,等響應(yīng)內(nèi)容渲染到頁(yè)面時(shí)再移除動(dòng)畫

先放loading效果圖

原理:偽類+動(dòng)畫,下面是步驟圖,貼上助于理解,加載動(dòng)畫本質(zhì)是設(shè)置一個(gè)定寬定高的正方形,border-radius: 50%;使其成為圓形,再給該div3px的邊框并設(shè)為透明,然后在單獨(dú)設(shè)置上邊框?yàn)榘咨?,?:before,::after偽類absolute定位并進(jìn)行同樣設(shè)置,不同之處是依次增大留出的間隙,以及動(dòng)畫執(zhí)行時(shí)間變長(zhǎng)和設(shè)置延遲,這樣就能形成圓圈不同快慢的旋轉(zhuǎn)

完整代碼:

components文件夾下loading.vue

<template>
  <div id="loader_wrapper">
    <div id="loader"></div>
    <div class="load_title">正在加載,請(qǐng)稍等......</div>
  </div>
</template>
<script>
  export default{
      name:"loading",
  }
</script>
<style scoped>
#loader_wrapper{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99;
  background: rgba(0, 0, 0,.8);
  background-size: 100% 100%;
}
#loader{
  display: block;
  position: relative;
  left: 50%;
  top: 50%;
  width: 300px;
  height: 300px;
  /* background: red; */
  margin: -150px 0 0 -150px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: #fff;
  -webkit-animation: spin 5s linear infinite;
  -ms-animation: spin 5s linear infinite;
  -moz-animation: spin 5s linear infinite;
  -o-animation : spin 5s linear infinite;
  animation:spin 5s linear infinite;
  z-index: 1001;
}
#loader:before{
  content:"";
  position: absolute;
  top: 5px;
  left: 5px;
  right: 5px;
  bottom: 5px;
  border-radius: 50%;
  /* background: green; */
  border: 3px solid transparent;
  border-top-color: #fff;
   -webkit-animation: spin 8s linear infinite;
  -ms-animation: spin 8s linear infinite;
  -moz-animation: spin 8s linear infinite;
  -o-animation : spin 8s linear infinite;
  animation:spin 8s linear infinite;
}
#loader:after{
  content:"";
  position: absolute;
  top: 15px;
  left: 15px;
  right: 15px;
  bottom: 15px;
  border-radius: 50%;
  /* background: yellow; */
  border: 3px solid transparent;
  border-top-color: #fff;
   -webkit-animation: spin 8s linear 1s infinite;
  -ms-animation: spin 8s linear 1s infinite;
  -moz-animation: spin 8s linear 1s infinite;
  -o-animation : spin 8s linear 1s infinite;
  animation:spin 8s linear 1s infinite;
}
@-webkit-keyframes spin {
  0%{
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform:rotate(0deg);
  }
  100%{
    -webkit-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
 
@keyframes spin{
  0%{
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform:rotate(0deg);
  }
  100%{
    -webkit-transform: rotate(360deg);
    -ms-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
#loader_wrapper .load_title{
  font-family: "Open Sans";
  color:#fff;
  font-size: .3rem;
  width: 100%;
  text-align: center;
  z-index: 9999;
  position: absolute;
  top: 70%;
  opacity: 1;
  line-height: .3rem;
}
</style>

在cs.vue頁(yè)面中引入并注冊(cè)loading

cs.vue

<template>
  <div class="main">
    <loading v-if="!initFlag"></loading>
    111
  </div>
</template>
 
<script>
  import loading from "../components/loading"
  export default {
    name:"tranin",
    data () {
      return{
        initFlag:false,//初始化全局?jǐn)?shù)據(jù)的請(qǐng)求 false表示請(qǐng)求失敗
 
      }
      
    },
    components:{
      loading,
    }
  }
</script>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論