如何在Gridsome中处理转场和动画

时间:2019-10-30 06:06:47

标签: vue.js gridsome

当前,我一直在VueJS的CDN内联版本中使用此代码,并且效果很好,但是当我将其添加到网格对象时,动画上的click事件无法打开幻灯片。

我已经查过输入页面的动画正在工作,但是我不确定如何处理组件动画。

动画在Gridsome中工作吗?

    <template>
  <nav class="navbar fixed-top navbar-expand-lg navbar-light bg-light">
    <div class="row">
      <div class="col">
        <button
          @click="show = !show"
          class="navbar-toggler"
          type="button"
        >
          <span class="navbar-toggler-icon"></span>
        </button>
      </div>
      <div class="col">
        <a class="navbar-brand" href="/">Navbar</a>
      </div>
    </div>
    <div>
      <transition name="slidein">
        <div v-if="show" class="nav-bar">
          <button
            @click="show = !show"
            class="btn-close pl-4 p-3"
            type="button"
          ></button>
          <span class="close-btn">X</span>
          <div class="d-flex flex-column"></div>
        </div>
      </transition>

      <transition name="fadein">
        <div v-if="show = show" class="bck-close" @click="show = !show"></div>
      </transition>
    </div>
  </nav>
</template>
<script>
export default {
  name: "headNav",
  data: {
    show: false
  },
};
</script>

<style>
.nav-bar {
  height: 100vh;
  width: 80vw;
  background: #fff;
  position: absolute;
  left: 0;
  z-index: 10000;
  overflow-x: hidden;
  overflow-y: auto;
  top: 0;
}

.btn-close {
  background: none;
  border: none;
  font-size: 1em;
}

.bck-close {
  height: 100vh;
  width: 100vw;
  background: rgba(0, 0, 0, 1);
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  opacity: 0.1;
  cursor: pointer;
}

.slidein-enter-active {
  animation: slidein 0.2s;
}
.slidein-leave-active {
  animation: slidein 0.2s reverse;
}
@keyframes slidein {
  from {
    left: -100%;
    width: 0%;
  }

  to {
    left: 0;
    width: 80vw;
  }
}

.fadein-enter-active {
  animation: fadein 0.2s;
}
.fadein-leave-active {
  animation: fadein 0.2s reverse;
}
@keyframes fadein {
  from {
    opacity: 0;
  }

  to {
    opacity: 0.1;
  }
}
</style>

1 个答案:

答案 0 :(得分:0)

弄错了数据部分,动画起作用了!

<script>
    export default {
      name: "headNav",
      data () {
          return {
            show: false
        }
      },
    };
</script>