5

アニメーションでjavascriptメソッドscrollTo(x、y)を実行する必要があります。jQueryを使用してそれを行うことはできません。

4

2 に答える 2

9

[作業デモ]

function interpolate( source,target,pos ) { 
  return ( source + (target - source) * pos ); 
}

function easing( pos ) { 
    return ( -Math.cos( pos * Math.PI ) / 2 ) + 0.5; 
}

function scrollTop( duration ) {

  duration = duration || 1000;

  var startY = window.pageYOffset,
      start  = Number(new Date()),
      finish = start + duration;

  var interval = setInterval(function() {

    var now = Number(new Date()),
        pos = (now > finish) ? 1 : (now - start) / duration;

     scrollTo(0, interpolate( startY, 0, easing(pos) ));

     if ( now > finish )
       clearInterval( interval );
  }, 15);
};
于 2010-11-02T23:07:28.540 に答える
2

window.setTimeout()およびwindow.clearTimeout()呼び出しを使用して、Javascriptで(ほとんど)何でもアニメーション化できます。http://www.w3schools.com/js/js_timing.aspを参照してください

于 2010-11-02T22:38:23.677 に答える