网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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中多个元素或组件的过渡
URL网址:http://bjjierui.cn/article/jchocc.html

其他资讯