How to horizontally move a div as you scroll down in javascript and or css

前端 未结 1 1062
说谎
说谎 2021-01-26 23:06

Does anybody know how can I get the effect of a carousel like the one in the bottom of this site https://brand.twitch.tv/ ??

I was using this example I found in codepen

1条回答
  •  太阳男子
    2021-01-26 23:30

    One way to achieve this is by using Scrollmagic. The learning curve is a little steep but the rewards are worth it.

    https://codepen.io/sean_pwc/pen/wvaaYWE

    I've forked your pen and amended slightly. Here's how it works.

    1) We add a bunch of divs that we want to be part of the normal page scroll. Nothing new here.

    1
    2
    3
    Last

    I've set a height of 300px and the boxes take up full width of the screen. Then we add a section that we'd like to scroll horizontally. Notice the change in styles on the boxes - flex-direction is set to row, so that the boxes sit next to each other, and we set a width on them.

    1
    2
    3
    4

    The comes the magic.

    var controller = new ScrollMagic.Controller();
    
    var scrollHorizontal = new TimelineLite()
      scrollHorizontal.to("#scrollHorizontal", 1, {x:'-100%'})
    
    var horizontalScroll = new ScrollMagic.Scene({
          triggerElement: "#scrollHorizontal",
          triggerHook: 'onLeave',
          duration: 3000
        }).setPin("#scrollHorizontal").setTween(scrollHorizontal).addTo(controller);
    

    I recommend you read the docs and play around with the demos to figure out whats going on. But essentially you set a controller which contains your animations.

    var controller = new ScrollMagic.Controller();
    

    Then we target the element we would like to move. Here, we target #scrollHorizontal, which is the wrapper for the h-boxes, and then we tell it move itself all the way over to the left until it is off the screen. Like you would position a side nav off the screen.

    var scrollHorizontal = new TimelineLite()
      scrollHorizontal.to("#scrollHorizontal", 1, {x:'-100%'})
    

    Now this will work, but the vertical scroll will still take effect, and it won't feel great. So we pin the element to be scrolled to the top of the screen - essentially scrollmagic adds a bunch of whitespace (set by the duration key, which is a height in pixels), which the user scrolls through, but it is hidden behind the pin, and we just see whatever you set to happen in scrollHorizontal (which was to move completely to the left).

    var horizontalScroll = new ScrollMagic.Scene({
          triggerElement: "#scrollHorizontal",
          triggerHook: 'onLeave',
          duration: 3000
        }).setPin("#scrollHorizontal").setTween(scrollHorizontal).addTo(controller);
    

    So we set a target element, and when the browser detects it, the element is pinned, the animation you declared in newTimelineLite() is actioned, for the duration you set, and then when the duration is over, we un-pin and go back to a natural vertical scroll. Play around with duration to change the speed of the horizontal scroll.

    References:

    https://scrollmagic.io/ https://scrollmagic.io/docs/index.html

    EDIT

    I should add, the codepen is using 4 scripts:

    https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js
    https://cdnjs.cloudflare.com/ajax/libs/gsap/2.1.3/TweenMax.min.js
    https://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.7/ScrollMagic.min.js
    https://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.7/plugins/animation.gsap.min.js
    

    0 讨论(0)
提交回复
热议问题