亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Vue中多個元素、組件的過渡及列表過渡的方法示例

2019-11-19 12:09:16
字體:
來源:轉載
供稿:網友

多個元素之間過渡動畫效果

多元素之間如何實現過渡動畫效果呢?看下面代碼

.fade-enter,.fade-leave-to{  opacity: 0;}.fade-enter-active,.fade-leave-active{  transition: opacity 3s;}<div id="root">  <transition name="fade">    <div v-if="show">hello world</div>    <div v-else>bye world</div>  </transition>  <button @click="handleClick">切換</button></div>let vm = new Vue({  el: '#root',  data: {    show: true  },  methods: {    handleClick() {      this.show = !this.show    }  }})

這么寫行不行呢?肯定是不行的,因為 Vue 在兩個元素進行切換的時候,會盡量復用dom,就是因為這個原因,導致現在動畫效果不會出現。

如果不讓 Vue 復用dom的話,應該怎么做呢?只需要給這兩個div不同的key值就行了

<div v-if="show" key="hello">hello world</div><div v-else key="bye">bye world</div>

這個時候當div元素進行切換的時候,就不會復用了。

mode

Vue 提供了一mode屬性,來實現多個元素切換時的效果

mode取值in-out,動畫效果是先出現在隱藏

<div id="root">  <transition name="fade" mode="in-out">  //第一次點擊時,執行順序為:①②    <div v-if="show">hello world</div> //再消失 ②    <div v-else>bye world</div>    //先顯示 ①  </transition>  <button @click="handleClick">切換</button>  </div>

mode取值為out-in,動畫效果為先隱藏在出現

<div id="root">  <transition name="fade" mode="out-in">  //第一次點擊時,執行順序為:①②    <div v-if="show">hello world</div> //先消失 ①    <div v-else>bye world</div>    //再顯示 ②  </transition>  <button @click="handleClick">切換</button>  </div>

多個組件之間過渡動畫效果

這里需要借助動態組件來實現多組件之間過渡動畫效果

先用普通的方式來實現切換:

.fade-enter,.fade-leave-to{  opacity: 0;}.fade-enter-active,.fade-leave-active{  transition: opacity 1s;}<div id="root">  <transition name="fade" mode="in-out">    <child-one v-if="show"></child-one>    <child-two v-else></child-two>  </transition>  <button @click="handleClick">切換</button></div>Vue.component('child-one',{  template:'<div>child-one</div>'})Vue.component('child-two',{  template:'<div>child-two</div>'})let vm = new Vue({  el: '#root',  data: {    show: true  },  methods: {    handleClick() {      this.show = !this.show    }  }})

你會發現,這樣子實現組件切換,transition動畫效果是存在的,但是我們想要用動態組件來實現,該怎么弄呢?

可查看之前的文章:Vue 動態組件與 v-once 指令,這篇文章中詳細的介紹了 Vue 的動態組件

列表過渡

這里需要使用一個新標簽transition-group來是實現

.fade-enter,.fade-leave-to{  opacity: 0;}.fade-enter-active,.fade-leave-active{  transition: opacity 1s;}<div id="root">  <transition-group name="fade">    <div v-for="item of list" :key="item.id">{{item.title}}-----{{item.id}}</div>  </transition-group>  <button @click="handleClick">添加</button></div>let vm = new Vue({  el: '#root',  data: {    count:0,    list:[]  },  methods: {    handleClick() {      this.list.push({        id:this.count ++,        title:'hello world'      })    }  }})

為什么使用了transition-group標簽后,就可以出現過渡動畫效果了呢?看下面代碼:

<transition-group name="fade">  <div>hello world</div>  <div>hello world</div>  <div>hello world</div></transition-group>

在循環過后,頁面中會出現一個個div元素,如果你在外面添加一個transition-group的標簽,相當于你在每一個div外層都加了一個transition標簽,看下面代碼

<transition>  <div>hello world</div></transition><transition>  <div>hello world</div></transition><transition>  <div>hello world</div></transition>

這時候,Vue 把列表的過渡轉化為單個的div元素的過渡了,Vue 會在這個元素隱藏或者顯示的時候動態的找到時間點,增加對應的class。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产日韩精品| 亚洲性视频网站| 亚洲aⅴ日韩av电影在线观看| 欧美综合在线第二页| 欧美一区二区三区四区在线| 久久国内精品一国内精品| 日韩欧美国产骚| 亚洲午夜激情免费视频| 2018中文字幕一区二区三区| 中文字幕亚洲自拍| 国产有码一区二区| 伊人伊成久久人综合网站| 欧美成人黄色小视频| 国产精品久久久久久久久久免费| 亚洲女在线观看| 中文字幕久久亚洲| 亚洲欧美日韩一区二区三区在线| 色吧影院999| 爽爽爽爽爽爽爽成人免费观看| 亚洲精品一区av在线播放| 久久精品国产v日韩v亚洲| 这里只有精品在线观看| 国模精品视频一区二区| 久久国产天堂福利天堂| 久久国产精品网站| 欧美成人精品激情在线观看| 亚洲欧美国产精品久久久久久久| 欧美电影免费观看高清| 亚洲色图13p| 日韩成人黄色av| 亚洲japanese制服美女| 精品亚洲国产视频| 伊人久久综合97精品| 日本一区二区在线播放| 亚洲美女又黄又爽在线观看| 欧美激情免费视频| 精品久久久久久亚洲国产300| 亚洲精品aⅴ中文字幕乱码| 亚洲欧美制服中文字幕| 姬川优奈aav一区二区| 亚洲欧美成人一区二区在线电影| 欧美激情国产精品| 中文字幕日韩视频| 欧美最猛性xxxxx免费| 欧洲亚洲妇女av| 国产视频综合在线| 欧美精品福利在线| 欧美夜福利tv在线| 亚洲已满18点击进入在线看片| 久久精品久久久久电影| 91精品国产综合久久久久久久久| 欧美第一淫aaasss性| 97国产成人精品视频| 日韩精品黄色网| 国产精品久久久久久一区二区| 欧美成人性色生活仑片| 97**国产露脸精品国产| 亚洲精品在线91| 亚洲精品aⅴ中文字幕乱码| 国产欧美精品日韩| 色偷偷88888欧美精品久久久| 最近2019免费中文字幕视频三| 日韩欧美在线字幕| 欧美成人精品在线播放| 亚洲精品福利在线| 中文字幕少妇一区二区三区| 欧美成人一二三| 久青草国产97香蕉在线视频| 日韩中文字在线| 久久五月天色综合| 色与欲影视天天看综合网| 亚洲电影第1页| 日韩美女视频在线观看| 91免费看视频.| 精品国内亚洲在观看18黄| 国产区精品视频| 精品视频在线播放色网色视频| www.久久色.com| 精品调教chinesegay| 日韩av免费看| 亚洲第一中文字幕在线观看| 欧美日韩国产丝袜另类| 国产欧美一区二区三区视频| 国产剧情日韩欧美| 丝袜亚洲另类欧美重口| 欧美精品videossex88| 日韩网站免费观看高清| 国产精品aaaa| 国产成人精品电影| 国产99久久精品一区二区 夜夜躁日日躁| 日韩中文字幕av| 日韩国产欧美精品一区二区三区| 国产欧美日韩中文字幕| 在线成人中文字幕| 欧美成人免费全部| 欧美视频在线观看免费网址| 亚洲18私人小影院| 亚洲日本欧美日韩高观看| 国产精品久久久久久久美男| 国产一区二区精品丝袜| 国产精品日韩在线播放| 日韩精品在线视频观看| 91久久久久久久| 亚洲国产一区二区三区四区| 日韩最新在线视频| 日韩中文字幕第一页| 国产精品扒开腿爽爽爽视频| 国产精品91久久久久久| 亚洲欧洲国产伦综合| 国产精品一久久香蕉国产线看观看| 欧美极品少妇xxxxⅹ喷水| 日韩精品在线第一页| 亚洲欧美三级在线| 日韩欧美在线免费观看| 久久国产色av| 亚洲欧美中文日韩在线v日本| 91免费在线视频网站| 国产精品女主播视频| 国产亚洲人成网站在线观看| 91精品久久久久久| 欧美日韩国产精品一区二区三区四区| 9.1国产丝袜在线观看| 国产性猛交xxxx免费看久久| 91精品国产高清自在线| 在线亚洲欧美视频| 91黑丝在线观看| 26uuu久久噜噜噜噜| 欧美日韩国产精品一区| 国产精品视频午夜| 国产精品成人一区| 欧美大片网站在线观看| 91高清视频在线免费观看| 亚洲成人久久电影| 精品色蜜蜜精品视频在线观看| 亚洲精品少妇网址| 欧美午夜xxx| 国产91成人video| 伦伦影院午夜日韩欧美限制| 国产精品av电影| 美乳少妇欧美精品| 国产亚洲精品久久久久久牛牛| 亚洲国产日韩欧美在线动漫| 亚洲精品久久久久中文字幕二区| 成人福利视频网| 欧洲s码亚洲m码精品一区| 久久国产精品首页| 成人激情电影一区二区| 91久热免费在线视频| 一本色道久久88亚洲综合88| 国产精品9999| 美日韩精品免费观看视频| 一区二区三区国产视频| 欧美视频在线观看免费| 欧美大片免费看| 欧美在线免费视频| 91精品国产乱码久久久久久久久| 91视频免费在线| 日韩精品在线观看一区| 伊人久久精品视频| 精品视频在线播放色网色视频| 成人国内精品久久久久一区| 疯狂蹂躏欧美一区二区精品| 69久久夜色精品国产69乱青草| 91精品久久久久久综合乱菊|