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

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 13:36:44
字體:
來源:轉載
供稿:網友

使用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可以正常運動,不過這種方式只能先后完成動畫,不能同時完成動畫。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 十堰市| 吐鲁番市| 沛县| 花莲县| 耿马| 青田县| 景德镇市| 内乡县| 资中县| 聂拉木县| 洞口县| 安顺市| 廊坊市| 大渡口区| 阿拉善右旗| 荆门市| 普兰县| 教育| 尚志市| 白城市| 七台河市| 铅山县| 肇州县| 阳城县| 南华县| 安溪县| 宁阳县| 柳河县| 文山县| 通河县| 福建省| 邵阳市| 南平市| 齐河县| 邓州市| 绥化市| 襄城县| 怀集县| 达日县| 睢宁县| 青海省|