vue切换组件动画 / vue-transition过渡动画

transition过渡

文档: https://cn.vuejs.org/v2/guide/transitions.html#CSS-%E8%BF%87%E6%B8%A1
transition标签包裹router-view or 状态切换的标签 才能实现过度动效!!!

v-enter / v-leave: 进入/离开过度的开始状态;
v-enter-to / v-leave-to: 进度/离开过度的结束状态;
v-enter-active / v-leave-active: 进入/离开过度时的生效状态;

提供了以上6个类名 or 使用name自定义transition

<style type="text/css">
    .cc-enter-active,  .cc-leave-active{  /* 进入 / 离开 过度生效状态 */
        transition: all .5s;
    }
    .cc-enter,  .cc-leave-to{             /* 进入状态 & 结束状态 opacity为0 */
        opacity: 0;
        transform: translateX(10px);
    }
</style>
<div id="app">

    <button @click="isShow = !isShow">click</button>

     <transition name="cc">      <!---使用过度自定义name--->
         <div v-show="isShow">11</div>
     </transition>
</div>
<style type="text/css">

    .v-enter{                           /*过度进入时初始状态*/
        opacity: 0;
        transform: translateX(100px);
    }
    .v-enter-to, .v-leave{              /*进入过度结束状态 & 过度结束离开初始状态*/
        opacity: 1;
        transform: translateX(0px);
    }

    .v-leave-to{                        /*过度结束状态*/
        opacity: 0;
        transform: translateX(-100px);
    }
    .v-enter-active,.v-leave-active{    /*过度动效*/
        transition: all .2s ease;
    }
    p{
        position: absolute;    /* 解决当translateX 进入和离开时的状态 朝同一方向移动时,会发生该节点从Dom树上删除而导致重绘 发生闪跳*/
    }
</style>
<div id="app">

    <button @click="isShow = !isShow">click</button>

    <div>
        <transition>   
                <p key="1" v-if="isShow">Lorem ipsum dolor sit amet.</p>
                <p key="2" v-else>no data</p>
        </transition>
    </div>  
</div>

vue 动画
<style type="text/css">
    .sss-enter-active {            /*进入时执行的动画*/
      animation: mmm .5s;
    }
    .sss-leave-active {             /*离开时执行的动画*/
      animation: mmm .5s reverse;  /*reverse 进入时0%到100%,离开时100%到0%*/
    }
    @keyframes mmm {
      0% {
        transform: scale(0);
      }
      50% {
        transform: scale(1.5);
      }
      100% {
        transform: scale(1);
      }
    }
    div{
        max-width: 200px;
    }
</style>
<div id="app">

    <button @click="isShow = !isShow">click</button>

    <div>
        <transition name="sss">
                <p v-if="isShow">Lorem ipsum dolor sit amet.</p>
        </transition>
    </div>  
</div>
自定义过度类名 & animate.css第三方动画插件结合使用
<div id="app">

    <button @click="isShow = !isShow">click</button>

    <transition 
        enter-active-class="animated bounce"            //进入时动效
        leave-active-class="animated bounceOutRight">   //离开时动效

        <p v-show="isShow">22222</p>

    </transition>
</div>
先引入animate.css
多元素过度
<style type="text/css">

    .sss-enter-active {
      animation: mmm .2s;
    }
    .sss-leave-active {
      animation: mmm .2s reverse;
    }
    @keyframes mmm {
        0% {
            opacity: 0;
            transform: translateX(100px);
        }
        100% {
            opacity: 1;
            transform: translateX(0px);
        }
    }
    div{
        max-width: 200px;
    }
</style>
<div id="app">

    <button @click="isShow = !isShow">click</button>

    <div>
        <transition name="sss" mode="out-in">  //不添加mode就是同时
                <p key="1" v-if="isShow">Lorem ipsum dolor sit amet.</p>
                <p key="2" v-else>no data</p>
        </transition>
    </div>  
</div>

<style type="text/css">

    .sss-enter-active {
      animation: sta .2s;
    }
    .sss-leave-active {
      animation: lea .2s;
    }
    @keyframes sta {
        0% {
            opacity: 0;
            transform: translateX(100px);
        }
        100% {
            opacity: 1;
            transform: translateX(0px);
        }
    }
    @keyframes lea {
        0% {
            opacity: 1;
            transform: translateX(0px);
        }
        100% {
            opacity: 0;
            transform: translateX(-100px);
        }
    }
    div{
        max-width: 200px;
        position: relative;
    }
    p{
        position: absolute;
    }
</style>
<div id="app">

    <button @click="isShow = !isShow">click</button>

    <div>
        <transition name="sss">   
                <p key="1" v-if="isShow">Lorem ipsum dolor sit amet.</p>
                <p key="2" v-else>no data</p>
        </transition>
    </div>  
</div>

实际应用

app.vue中设置页面切换全局动画

  <template>
  <div class="app-container">
     <!-- 页头 -->
     <mt-header v-show="$route.meta.showHeader" class="mt-header" fixed title="vue-project">
          <span slot="left" @click="goBack" v-show="flag">
                  <mt-button icon="back">返回</mt-button>
          </span>
     </mt-header> 


 <!-- 点击tabbar中间的内容切换动画  step1.-->
     <transition mode="out-in">
              <!-- 点击tabbar组件跳转不同的页面,共同显示的中间内容 -->
        <router-view></router-view> 
     </transition>


 <!-- tablebar -->
    <nav class="mui-bar mui-bar-tab">
        <router-link class="mui-tab-item-li" to="/home"> <!--在index.js中linkactive被替换的mui-active-->
            <span class="mui-icon mui-icon-home"></span>
            <span class="mui-tab-label">首页</span>
        </router-link>

        <router-link class="mui-tab-item-li" to="/member">
            <span class="mui-icon mui-icon-contact"></span>         
            <span class="mui-tab-label">会员</span>
        </router-link>

        <router-link class="mui-tab-item-li" to="/cart">
            <span class="mui-icon mui-icon-extra mui-icon-extra-cart"><span class="mui-badge">{{$store.getters.getAllCount}}</span></span>
            <span class="mui-tab-label">购物车</span>
        </router-link>

        <router-link class="mui-tab-item-li" to="/search">
            <span class="mui-icon mui-icon-search"></span>
            <span class="mui-tab-label">搜素</span>
        </router-link>
    </nav>

</div>
</template>

style

.app-container{
padding-top: 40px;
padding-bottom: 50px;     /*设置导航头与tabbar占据空间,是为了中间显示内容不会隐藏到those的背后*/

overflow-x: hidden;       /*隐藏动画translateX(-100%)多余部分  step3.*/

/* max-width: 600px; */
/* margin: 0 auto; */
}

.v-enter,
.v-leave-to{
opacity: 0;
transform: translateX(-100%);
}
.v-enter-active,.v-leave-active{
transition: all 0.2s ease;
}
/* 结合transition使用的过渡切换效果  
  进入和离开时的动画,都是页面向左整个移动整个页面距离
step2.*/
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容