vue 中使用css3制作加载动画

<template>

    <div class="loader"></div>

</template>

 

<script>

export default {

    name : 'Loading'

}

</script>

 

<style scoped>

.loader {

  position: relative;

  width: 2.5em;

  height: 2.5em;

  transform: rotate(165deg);

}

.loader:before, .loader:after {

  content: '';

  position: absolute;

  top: 50%;

  left: 50%;

  display: block;

  width: 0.5em;

  height: 0.5em;

  border-radius: 0.25em;

  transform: translate(-50%, -50%);

}

.loader:before {

  animation: before 2s infinite;

}

.loader:after {

  animation: after 2s infinite;

}

 

@keyframes before {

  0% {

    width: 0.5em;

    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);

  }

  35% {

    width: 2.5em;

    box-shadow: 0 -0.5em rgba(225, 20, 98, 0.75), 0 0.5em rgba(111, 202, 220, 0.75);

  }

  70% {

    width: 0.5em;

    box-shadow: -1em -0.5em rgba(225, 20, 98, 0.75), 1em 0.5em rgba(111, 202, 220, 0.75);

  }

  100% {

    box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);

  }

}

@keyframes after {

  0% {

    height: 0.5em;

    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);

  }

  35% {

    height: 2.5em;

    box-shadow: 0.5em 0 rgba(61, 184, 143, 0.75), -0.5em 0 rgba(233, 169, 32, 0.75);

  }

  70% {

    height: 0.5em;

    box-shadow: 0.5em -1em rgba(61, 184, 143, 0.75), -0.5em 1em rgba(233, 169, 32, 0.75);

  }

  100% {

    box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);

  }

}

/**

 * Attempt to center the whole thing!

 */

html,

body {

  height: 100%;

}

 

.loader {

  position: absolute;

  top: calc(50% - 1.25em);

  left: calc(50% - 1.25em);

}

 

</style>

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值