it-swarm.com.ru

анимация прокрутки с помощью CSS3

Есть ли способ анимировать прокрутку с помощью CSS3?

Что-то вроде этого?

@-webkit-keyframes scrolltoview
{
    0%   { scrollTop: 0; }
    100% { scrollTop: 30%; }
}

Как поставить в CSS, где находится начальная точка анимации?

18
Spiff

анимации css3 работают только со свойствами css. это невозможно в рамках css.

9
David Wick

Как объяснено здесь вы можете сделать это, используя трюк margin-top и динамически обновляя позицию прокрутки. Вы можете проверить демо . Код прост:

// Define the variables
var easing, e, pos;
$(function(){
  // Get the click event
  $("#go-top").on("click", function(){
    // Get the scroll pos
    pos= $(window).scrollTop();
    // Set the body top margin
    $("body").css({
      "margin-top": -pos+"px",
      "overflow-y": "scroll", // This property is posed for fix the blink of the window width change 
    });
    // Make the scroll handle on the position 0
    $(window).scrollTop(0);
    // Add the transition property to the body element
    $("body").css("transition", "all 1s ease");
    // Apply the scroll effects
    $("body").css("margin-top", "0");
    // Wait until the transition end
    $("body").on("webkitTransitionEnd transitionend msTransitionEnd oTransitionEnd", function(){
      // Remove the transition property
      $("body").css("transition", "none");
    });
  });
});

@AndrewP предоставил хороший рабочий пример основанный на этой идее

15
mente

Я обнаружил лучший способ анимации прокрутки, который заключается в использовании JavaScript для перевода тела документа. Преимущества анимации с помощью translate над полем или позицией довольно хорошо задокументированы . Суть в том, что при анимации элементов графический процессор всегда будет работать лучше. 

Вот пример, который вычисляет текущую позицию пользователя из верхней части окна, а затем плавно переводит обратно в верхнюю часть окна. Предположим, что пользовательский щелчок или событие касания вызвало функцию backToTop.

Посмотрите это в действии: https://antibland.github.io/starting_point/

function whichTransitionEvent() {
  var t,
      el          = document.createElement('fakeelement'),
      transitions = {
        'transition':'transitionend',
        'OTransition':'oTransitionEnd',
        'MozTransition':'transitionend',
        'WebkitTransition':'webkitTransitionEnd'
     };

  for (t in transitions){
    if (el.style[t] !== undefined){
      return transitions[t];
    }
  }
}

function backToTop() {
  var pos_from_top  = window.scrollY,
      transitionend = whichTransitionEvent(),
      body          = document.querySelector("body");

  function scrollEndHandler() {
    window.scrollTo(0, 0);
    body.removeAttribute("style");
    body.removeEventListener(transitionend, scrollEndHandler);
  }

  body.style.overflowY = "scroll";
  window.scrollTop = 0;

  body.style.webkitTransition = 'all .5s ease';
  body.style.transition = 'all .5s ease';

  body.style.webkitTransform = "translateY(" + pos_from_top + "px)";
  body.style.transform = "translateY(" + pos_from_top + "px)";

  transitionend && body.addEventListener(transitionend, scrollEndHandler);
}
4
Andy Hoffman

Это очень простая функция .js, которую я сделал для анимации + прокрутки веб-страницы.

var Current_scroll_Y=0;
var Target_scroll_Y=0;
var scroll_Speed = 15;

function animate_Scroll(Y)
{
  Target_scroll_Y = Y;
  screen_Y = Math.floor(window.scrollY);

  //Scroll Down
  if(screen_Y<Y)
  {
    var myWindowScroll = setInterval(function(){ screen_Y = screen_Y+scroll_Speed;  if(screen_Y>=Target_scroll_Y){ clearInterval(myWindowScroll); return;}    window.scrollTo(0, screen_Y); }, 3);   
  }
  //Scroll Up
  if(screen_Y>Y)
  {
    var myWindowScroll = setInterval(function(){ screen_Y = screen_Y-scroll_Speed;  if(screen_Y<=Target_scroll_Y){ clearInterval(myWindowScroll); return;}    window.scrollTo(0, screen_Y); }, 3);  
  } 


}//End animate_Scroll  
1
Really Nice Code

Я не думаю, что это возможно с css3, но если я правильно понимаю ваш вопрос, это очень легко с jquery.

Проверять, выписываться:

http://demos.flesler.com/jquery/scrollTo/

http://api.jquery.com/scroll/

0
Connor