国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

使用vue的transition完成滑動過渡的示例代碼

2024-05-06 15:33:08
字體:
來源:轉載
供稿:網友

使用vue來做一些小巧的動畫效果是非常方便的,今天本人想使用vue的transition來完成一個滑動過渡效果,這里和大家分享一下。

直接上源代碼:

<!DOCTYPE html><html><head>  <meta charset="utf-8">  <title>Vue滑動效果</title>  <style>    .d {      position: absolute;      border: 1px solid red;      width: 30px;      height: 30px;    }    @keyframes show {      0% {        opacity: 0;        left: 32px;      }      100% {        opacity: 1;        left: 0;      }    }    @keyframes hide {      0% {        opacity: 1;        left: 0;      }      100% {        opacity: 0;        left: -32px;      }    }    .show-enter-active {      animation: show 1.2s;    }    .show-leave-active {      animation: hide 1.2s;    }    .show-enter, .show-leave-to {      opacity: 0;    }    .wrap {      position: relative;      width: 32px;      height: 32px;    }  </style>  <script src="https://cdn.bootcss.com/vue/2.4.2/vue.min.js"></script></head><body><div id="app">  <p>{{ message }}</p>  <div class="wrap">    <transition name="show">      <div class="d" v-for="item in list" :key="item.id" v-if="count === item.id">        {{ item.text }}      </div>    </transition>  </div>  <button @click="add">add</button></div><script>  new Vue({    el: '#app',    data () {      return {        message: 'Hello Vue.js!',        count: 0,        list: [          {id: 0, text: 'aaa'},          {id: 1, text: 'bbb'},          {id: 2, text: 'ccc'}        ]      }    },    methods: {      add: function () {        if (this.count < this.list.length - 1) {          this.count += 1;        } else {          this.count = 0;        }      }    }  })</script></body></html>

這里需要注意的是父級使用relative,子級使用absolute進行定位,利用left值來進行位置的控制移動。這里如果使用transform的話,由于之前的div有一個漸變的消失過程,這個過程中他的位置一直有存在,造成了后面的div無法正確移動到對應位置,所以使用absolute更好。

實在不行可以使用transition的mode屬性,設置成out-in,先讓前者完成動畫,讓占據的位置完全消失,使得下一個div可以正常運動,不過這種方式只能先后完成動畫,不能同時完成動畫。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 凤庆县| 慈利县| 赤水市| 锡林郭勒盟| 阜平县| 雅安市| 江华| 宁远县| 太仆寺旗| 六安市| 太保市| 潜山县| 聊城市| 湘潭县| 通江县| 平遥县| 武山县| 准格尔旗| 乐东| 西充县| 金乡县| 阜新市| 华亭县| 微博| 甘洛县| 洞口县| 巫溪县| 白沙| 新平| 华坪县| 穆棱市| 潼南县| 武宣县| 静宁县| 比如县| 澄江县| 潍坊市| 衡南县| 昌都县| 石景山区| 兖州市|