多个元素的过渡
  
  <style>
  
  .v-enter,.v-leave-to{
  
  opacity: 0;
  
  }
  
  .v-enter-acitve,.v-leave-active{
  
  opacity: opacity 1s;
  
  }
  
  </style>
  
  <div id='app'>
  
  <transition>
  
  <div v-if='show'>hello world</div>
  
  <div v-else>bye world</div>
  
  </transition>
  
  <button @click='handleClick'>切换</button>
  
  </div>
  
  <script>
  
  var vm = new Vue({
  
  el:'#app',
  
  data:{
  
  show:true
  
  },
  
  methods:{
  
  handleClick:function(){
  
  this.show = !this.show;
  
  }
  
  }
  
  })
  
  </script>
  
  //前端全栈学习交流圈:866109386
  
  //面向1-3经验年前端开发人员
  
  //帮助突破技术瓶颈,提升思维能力
  
  按照之前的写法方式,渐隐渐出的效果并没有出现该有的效果,那么为什么呢? 在if else两个元素切换的时候,会尽量的复用dom,正是vue,dom的复用,导致动画的效果不会出现,如果想要vue不去复用dom,之前也说过,怎么做呢,给两个div不同的key值就行了
  
  <div v-if='show' key='hello'>hello world</div>
  
  <div v-else key='bye'>bye world</div>
  
  这样就可以有个明显的动画效果,多个元素过渡动画的效果。
  
  transition还提供了一个mode属性,in-out是先显示再隐藏,out-in是先隐藏再显示
  
  多个组件的过渡
  
  <style>
  
  .v-enter, .v-leave-to {
  
  opacity: 0;
  
  }
  
  .v-enter-acitve, .v-leave-active {
  
  transition: opacity 1s;
  
  }
  
  </style>
  
  <div id='app'>
  
  <transition mode='out-in'>
  
  <child v-if='show'></child>
  
  <child-one v-else></child-one>
  
  </transition>
  
  <button @click='handleClick'>切换</button>
  
  </div>
  
  <script>
  
  Vue.component('child',{
  
  template:'<div>child</div>'
  
  })
  
  Vue.component(www.mingcheng178.com'child-one',{
  
  template:'<div>child-one</div>'
  
  })
  
  var vm = new Vue({
  
  el:'#app',
  
  data:{
  
  show:true
  
  },
  
  methods:{
  
  handleClick:function(www.gcyL157.com){
  
  this.show =www.mhylpt.com !this.show;
  
  }
  
  }
  
  })
  
  </script>
  
  //前端全栈学习交流圈:866109386
  
  //面向1-3经验年前端开发人员
  
  //帮助突破技术瓶颈,提升思维能力
  
  这个就是多个组件的过渡,采用的是上面的方式,替换子组件,那么我们换一种方式,用动态组件
  
  <style>
  
  .v-enter, .v-leave-to {
  
  opacity: 0;
  
  }
  
  .v-enter-acitve,www.gcyl152.com .v-leave-active {
  
  transition: opacity 1s;
  
  }
  
  </style>
  
  <div id=www.feifanyule.cn/'app'>
  
  <transition mode=www.haom178.com'out-in'>
  
  <component :is='type'></component>
  
  </transition>
  
  <button @click='handleClick'>切换</button>
  
  </div>
  
  <script>
  
  Vue.component('child',{
  
  template:'<div>child</div>'
  
  })
  
  Vue.component('child-one',{
  
  template:'<div>child-one</div>'
  
  })
  
  var vm = new Vue({
  
  el:'#app',
  
  data:{
  
  type:'child'
  
  },
  
  methods:{
  
  handleClick:function(){
  
  this.type = (this.type === 'child' ? 'child-one' : 'child')
  
  }
  
  }
  
  })
  
  </script>
  
  这样也实现了多个组件的过渡效果。

vue实现多个元素或多个组件之间动画效果的更多相关文章

  1. vue中多个元素或多个组件之间的动画效果

    多个元素的过渡 <style> .v-enter,.v-leave-to{ opacity: 0; } .v-enter-acitve,.v-leave-active{ opacity: ...

  2. ScrollReveal.js 用于创建和管理元素进入可视区域时的动画效果,帮助你的网站增加吸引力。

    ScrollReveal.js 用于创建和管理元素进入可视区域时的动画效果,帮助你的网站增加吸引力. 1.http://www.yangqq.com/jstt/css3/2017-08-08/787. ...

  3. 067——VUE中vue-router之使用transition设置酷炫的路由组件过渡动画效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. Vue 爬坑之路(二)—— 组件之间的数据传递

    Vue 的组件作用域都是孤立的,不允许在子组件的模板内直接引用父组件的数据.必须使用特定的方法才能实现组件之间的数据传递. 首先用 vue-cli 创建一个项目,其中 App.vue 是父组件,com ...

  5. (转)Vue 爬坑之路(二)—— 组件之间的数据传递

    Vue 的组件作用域都是孤立的,不允许在子组件的模板内直接引用父组件的数据.必须使用特定的方法才能实现组件之间的数据传递. 首先用 vue-cli 创建一个项目,其中 App.vue 是父组件,com ...

  6. Vue(基础四)_总结五种父子组件之间的通信方式

    一.前言 这篇文章主要总结了几种通信方式: 1.方式一:使用props: [ ]和$emit()  (适用于单层通信) 2.方式二:$attrs和$listeners(适用于多层) 3.方式三:中央处 ...

  7. vue 学习五 深入了解components(父子组件之间的传值)

    上一章记录了 如何在父组件中向子组件传值,但在实际应用中,往往子组件也要向父组件中传递数据,那么此时我们应该怎么办呢 1.在父组件内使用v-on监听子组件事件,并在子组件中使用$emit传递数据 // ...

  8. vue中,模拟锚点定位,实现滚动动画效果

    平时我们利用锚点进行页面内的快速瞬移,画面跳转生硬,观感很差. 在VUE中,如何快速的实现锚点效果,并且还让它拥有滚动的动画效果呢. 其实两行代码就能解决问题 1 <a @click=" ...

  9. css3中变形函数(同样是对元素来说的)和元素通过改变自身属性达到动画效果

    /*对元素进行改变(移动.变形.伸缩.扭曲)*/ .wrapper{ margin:100px 100px auto auto; width:300px; height:200px; border:2 ...

随机推荐

  1. 触发ionic弹窗区域外的方法

    最近项目需要在页面弹窗的时候需要点击弹窗区域外的地方,其实也就是点击页面HTML就可以关闭弹窗, 首先在controller通过js获取到html的dom节点,然后绑定点击事件,话不多说上代码:   ...

  2. Dnsmasq域名解析系统安装配置

    Dnsmasq使用上比bind要简便得多,可以做正向.反向dns解析,支持DHCP服务.也可以做内部dns服务器用. 默认下,dnsmasq使用系统的/etc/resolv.conf,并读取/etc/ ...

  3. tcl之其他命令-eval/source

  4. php-语言参考-基本语法3.1

    一,PHP代码的开始和结束标记 1,<?php 和 ?> //重点 2,<script language="php"> 和 </script> ...

  5. 1014-34-首页15-计算原创微博的frame------计算cell的高度---计算 UILabel 的 CGSize 的方法

    一.总体思路: 在控制器中,每次拿到数据模型(请求了数据.加载新微博)的时候,就调用 - (NSArray *)stausFramesWithStatuses:(NSArray *)statuses, ...

  6. 匿名函数lambda python

    lambda 的主体是一个表达式,不是一个代码块lambda 只有一行,仅仅能在lambda表达式种封装有限的逻辑进去匿名函数:需要一个函数,而又不想动脑筋去想名字 #普通函数的定义 def f(a, ...

  7. Kali Linux 搜狗输入法安装

    1.下载 搜狗输入法 for Linux http://pinyin.sogou.com/linux/ //有64位和32位的deb包 我这里下载的是 : sogoupinyin_2.1.0.0086 ...

  8. android获取未安装APK签名信息及MD5指纹

    站在巨人的肩膀上写博客: http://blog.csdn.net/wulianghuan/article/details/18400581 http://www.jb51.net/article/7 ...

  9. 运行SparkStreaming程序时出现 Exception in thread "main" java.lang.NoSuchMethodError: scala.Predef$.ArrowA异常

    Exception in thread "main" java.lang.NoSuchMethodError: scala.Predef$.ArrowA 这个问题是版本不统一导致的 ...

  10. Python的类(一)

    类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例. 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外. ...