国产探花免费观看_亚洲丰满少妇自慰呻吟_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可以正常運動,不過這種方式只能先后完成動畫,不能同時完成動畫。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 安溪县| 通州区| 泉州市| 舒兰市| 河西区| 治县。| 永泰县| 泸州市| 东山县| 常熟市| 抚远县| 三门峡市| 石阡县| 深水埗区| 团风县| 泰来县| 固阳县| 绥滨县| 南充市| 昆山市| 梁山县| 台北市| 牟定县| 镇平县| 周至县| 乡宁县| 巴塘县| 焦作市| 永登县| 乌拉特中旗| 平陆县| 抚远县| 尼勒克县| 从江县| 新兴县| 孝昌县| 安康市| 收藏| 镇宁| 台东市| 四子王旗|