Create sliding left effect using Vuejs animation

后端 未结 2 491
臣服心动
臣服心动 2020-12-28 14:18

I\'ve read this official document about Vuejs animation. But using it css hooks, I can only make element appear/disappear with fade and different duration.

         


        
2条回答
  •  情歌与酒
    2020-12-28 15:04

    You can absolutely do this with VueJS. Have a look at the example under. You can see two examples, one is the adopted code for your case(to make it slide). And other is a simple image slider, that loops through array of images in 3 seconds interval.

    Important thing to note here, is that we wrap the image element in for loop to force the element to be destroyed, because otherwise your elements will not be removed from DOM and will not transition (virtual DOM).

    For better understanding of transitions in VueJS in recommend you to check out getting started guide - transition section.

    new Vue({
      el: '#demo',
      data: {
        message: 'Click for slide',
        show: true,
        imgList: [
            'http://via.placeholder.com/350x150',
          'http://via.placeholder.com/350x151',
          'http://via.placeholder.com/350x152'
        ],
        currentImg: 0
      },
      mounted() {
        setInterval(() => {
            this.currentImg = this.currentImg + 1;
        }, 3000);
      }
    })
    #demo {
      overflow: hidden;
    }
    
    .slide-leave-active,
    .slide-enter-active {
      transition: 1s;
    }
    .slide-enter {
      transform: translate(100%, 0);
    }
    .slide-leave-to {
      transform: translate(-100%, 0);
    }
    
    .img-slider{
      overflow: hidden;
      position: relative;
      height: 200px;
      width: 400px;
    }
    
    .img-slider img {
      position: absolute;
      top: 0;
      left: 0;
      bottom: 0;
      right:0;
    }
    
    
      
        VueJS 2.0 - image slider
        
      
    
      
        

    {{message}}

    Img slider

提交回复
热议问题