溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn)

發(fā)布時(shí)間:2020-08-29 20:43:23 來源:腳本之家 閱讀:263 作者:章魚喵_ 欄目:web開發(fā)

在transition中還可以通過設(shè)置javascript鉤子函數(shù),實(shí)現(xiàn)自定義動(dòng)畫效果。

以實(shí)現(xiàn)擊球效果為例:

vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn)

擊球

代碼解析:

<!-- 定義js的鉤子函數(shù) -->
<transition
  @before-enter="beforeEnter"
  @enter="enter"
  @after-enter="afterEnter"
>
  <img v-show="flag" class="ball" :src="ball" alt="" width="30">
</transition>
let vm = new Vue({
  el: "#app",
  data: {
    flag: false,
    ball: 'https://upload-images.jianshu.io/upload_images/1864602-ec73f549171a6601.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240'
  },
  methods: {
    // el 表示要執(zhí)行動(dòng)畫的那個(gè)DOM元素, 是原生的 js DOM 對(duì)象
    beforeEnter(el) {
      // 設(shè)置動(dòng)畫開始之前的初始位置
      el.style.transform = "translate(0, 0)"
    },
    enter(el, done) {
      // 刷新動(dòng)畫效果
      el.offsetWidth;
      // 動(dòng)畫完成后的樣式
      el.style.transform = "translate(550px, 350px)";
      // 動(dòng)畫的持續(xù)時(shí)間
      el.style.transition = "all 3s ease";
      // done 其實(shí)是 afterEnter() 的引用
      done();
    },
    afterEnter(el) {
      // 動(dòng)畫完成之后調(diào)用
      this.flag = !this.flag
    }
  }
})

完整代碼

<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet">
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<style>
  .container {
    margin-top: 2%;
  }
  img.ball {
    margin-left: 3%;
  }
</style>
<body>
<div class="container">
  <div id="app">
    <button class="btn btn-danger" @click="flag=!flag">擊球</button>
    <!-- 定義js的鉤子函數(shù) -->
    <transition
      @before-enter="beforeEnter"
      @enter="enter"
      @after-enter="afterEnter"
    >
      <img v-show="flag" class="ball" :src="ball" alt="" width="30">
    </transition>
  </div>
</div>
<script>
  let vm = new Vue({
    el: "#app",
    data: {
      flag: false,
      ball: 'https://upload-images.jianshu.io/upload_images/1864602-ec73f549171a6601.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240'
    },
    methods: {
      // el 表示要執(zhí)行動(dòng)畫的那個(gè)DOM元素, 是原生的 js DOM 對(duì)象
      beforeEnter(el) {
        // 設(shè)置動(dòng)畫開始之前的初始位置
        el.style.transform = "translate(0, 0)"
      },
      enter(el, done) {
        // 刷新動(dòng)畫效果
        el.offsetWidth;
        // 動(dòng)畫完成后的樣式
        el.style.transform = "translate(550px, 350px)";
        // 動(dòng)畫的持續(xù)時(shí)間
        el.style.transition = "all 3s ease";
        // done 其實(shí)是 afterEnter() 的引用
        done();
      },
      afterEnter(el) {
        // 動(dòng)畫完成之后調(diào)用
        this.flag = !this.flag
      }
    }
  })
</script>
</body>
</html>

最終效果:

vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn)

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

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI