Vue中多个元素或组件的过渡




    
    
    
    
    
    


    
        
            hello
            bye
                 切换     
             var vm = new Vue({             el: "#root",             data: {                 show: true             },             methods: {                 handleClick: function() {                     this.show = !this.show                 }             }         });     

(像上面这种加了style并不会实现渐变效果,因为vue默认是会尽量复用dom,想要vue不复用dom,要给其加上不同的key值)

专注于为中小企业提供成都网站建设、网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业尼金平免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上1000+企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

加上不同key值后,渐变效果有了:




    
    
    
    
    
    


    
        
            hello
            bye
        
        切换
    
    
        var vm = new Vue({
            el: "#root",
            data: {
                show: true
            },
            methods: {
                handleClick: function() {
                    this.show = !this.show
                }
            }
        });
    

如果想设置多个属性之间的切换效果,可以用mode(mode="in-out":先显示要显示的再隐藏要隐藏的。mode="out-in":和前面的相反):




    
    
    
    
    
    


    
        
            hello
            bye
        
        切换
    
    
        var vm = new Vue({
            el: "#root",
            data: {
                show: true
            },
            methods: {
                handleClick: function() {
                    this.show = !this.show
                }
            }
        });
    

组件动画也是可以的(不需要上面的不同值的key):




    
    
    
    
    
    


    
        
            hello
            bye
        
        切换
    
    
        Vue.component("child1", {
            template: "
child1
"         });         Vue.component("child2", {             template: "
child2
"         });         var vm = new Vue({             el: "#root",             data: {                 show: true             },             methods: {                 handleClick: function() {                     this.show = !this.show                 }             }         });     

动态组件的实现方法:




    
    
    
    
    
    


    
        
            //通过动态组件的方式实现:
            
        
        切换
    
    
        Vue.component("child1", {
            template: "
child1
"         });         Vue.component("child2", {             template: "
child2
"         });         var vm = new Vue({             el: "#root",             data: {                 type: "child1"             },             methods: {                 handleClick: function() {                     this.type = this.type == "child1" ? "child2" : "child1"                 }             }         });     

分享文章:Vue中多个元素或组件的过渡
网页路径:http://bzwzjz.com/article/jchocc.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站建设 成都网站建设 成都网站建设 网站建设方案 网站建设 做网站设计 成都网站建设 网站制作 盐亭网站设计 定制级高端网站建设 专业网站建设 网站制作 上市集团网站建设 定制网站建设多少钱 成都网站建设公司 成都网站建设推广 成都网站建设公司 高端定制网站设计 成都网站制作 LED网站设计方案 成都网站设计公司 网站设计