19

有没有办法用 CSS3 动画滚动?

像这样的东西?

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

如何在css中放入动画的起点在哪里?

4

5 回答 5

15

正如这里所解释的,您可以使用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基于这个想法提供了一个很好的工作示例

于 2013-06-19T11:57:41.693 回答
9

css3 动画仅适用于 css 属性。这在 css 的范围内是不可能的。

于 2012-04-21T22:10:01.533 回答
4

我发现了一种更好的滚动动画方法,即使用 JavaScript 来翻译文档正文。在边距或位置上使用 translate 进行动画制作的优势已得到很好的证明。底线是,在为元素制作动画时,GPU 总是会做得更好。

这是一个示例,它从窗口顶部计算用户的当前位置,然后平滑地转换回窗口顶部。假设用户点击或触摸事件触发了 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);
}
于 2014-12-18T07:30:46.810 回答
0

我认为css3不可能做到这一点,但是如果我正确理解了您的问题,那么使用jquery就很容易了。

查看:

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

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

于 2012-04-21T17:22:17.023 回答
0

这是一个非常简单的 .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  
于 2016-06-27T15:34:20.387 回答