JavaScript lintas browser (bukan jQuery ...) gulir ke animasi teratas

222

Saya mencari animasi "gulir ke atas" lintas-peramban yang sederhana yang dapat saya terapkan ke tautan. Saya tidak ingin memerlukan perpustakaan JS seperti jQuery / Moo, dll.

// jQuery Equivilant to convert to pure JS...
$('html, body').animate({scrollTop:0}, 400);

Saya kasus sempurna untuk seseorang yang seharusnya belajar JS 100% sebelum melompat ke perpustakaan. :(

Heather Hins
sumber
78
+1 karena tidak ingin menggunakan jQuery, dengan alasan yang valid :) Untuk inspirasi, Anda dapat melihat kode sumber perpustakaan ini, misalnya jquery-1.7.1.js .
Rob W
10
@seand JavaScript bukan jQuery, tetapi jQuery adalah JavaScript. Jika seseorang (seperti OP) ingin belajar JavaScript, ia tidak boleh menyentuh perpustakaan yang membengkak, kecuali mereka mendapat ide bagaimana menulis kode yang sama dalam JavaScript.
Rob W
3
@RobW menggunakan perpustakaan seperti jQuery membantu menghilangkan perbedaan lintas-peramban, jadi saya akan melihatnya penting untuk pengembangan web; Anda tidak perlu tahu perbedaan jika implementasi yang sangat baik ada dan tersedia secara bebas
seand
6
@ lihat dan itulah bagaimana kami menghasilkan coders jelek. Mereka tidak mengerti bahasa, tetapi dapat menghasilkan kode jQuery dalam jumlah yang tidak terbatas, karena mereka mengetahuinya. Ini mengarah ke peretasan seperti menyimpan segala sesuatu di DOM (karena kadang-kadang mereka bahkan tidak tahu apa variabelnya, selain var something = $(...)), menciptakan trilyun objek dalam setiap fungsi (mereka tahu variabel, tetapi tidak tahu bahwa var veryBigObject = {...}dengan beberapa ratus properti di bagian atas fungsi akan membunuh kinerja). Dan sangat sering mereka bahkan tidak tahu nama bahasa Javascript, bukan jQuery.
Killah

Jawaban:

139
function scrollTo(element, to, duration) {
    if (duration <= 0) return;
    var difference = to - element.scrollTop;
    var perTick = difference / duration * 10;

    setTimeout(function() {
        element.scrollTop = element.scrollTop + perTick;
        if (element.scrollTop === to) return;
        scrollTo(element, to, duration - 10);
    }, 10);
}

Demo:

function runScroll() {
  scrollTo(document.body, 0, 600);
}
var scrollme;
scrollme = document.querySelector("#scrollme");
scrollme.addEventListener("click",runScroll,false)

function scrollTo(element, to, duration) {
  if (duration <= 0) return;
  var difference = to - element.scrollTop;
  var perTick = difference / duration * 10;

  setTimeout(function() {
    element.scrollTop = element.scrollTop + perTick;
    if (element.scrollTop == to) return;
    scrollTo(element, to, duration - 10);
  }, 10);
}
<p>Very long page.Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page.  Very long page.Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page.  Very long page.Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page.  Very long page.Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page.  Very long page.Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page. Very long page.
</p>
<button id=scrollme type="button">To the top</button>

TimWolla
sumber
11
document.documentElementalih-alih document.body(kecuali Anda menetapkan CSS:) body{height:100%;}. Demo kerja menggunakan konsep ini: jsfiddle.net/S5ALP/1
Rob W
7
@RobW Tambahan Anda tidak berfungsi di sini di Google Chrome @ Ubuntu Linux
TimWolla
2
tidak di Firefox 9.0, Ubuntu juga :). Kode Anda gagal di Firefox, tetapi berfungsi di Chrome, kode saya gagal di Chrome, tetapi bekerja di FF.
Rob W
2
Itu seharusnyaif (duration <= 0) return;
Jon Koops
4
Memodifikasi untuk digunakan top.window.scroll(0, value)alih-alih element.scrollTop = valuemembuatnya bekerja di Chrome dan Firefox (Ubuntu). :)
Shomz
113

Sepertinya sudah ada banyak solusi. Lagi pula, inilah yang lain, menggunakan persamaan pelonggaran ..

// first add raf shim
// http://www.paulirish.com/2011/requestanimationframe-for-smart-animating/
window.requestAnimFrame = (function(){
  return  window.requestAnimationFrame       ||
          window.webkitRequestAnimationFrame ||
          window.mozRequestAnimationFrame    ||
          function( callback ){
            window.setTimeout(callback, 1000 / 60);
          };
})();

// main function
function scrollToY(scrollTargetY, speed, easing) {
    // scrollTargetY: the target scrollY property of the window
    // speed: time in pixels per second
    // easing: easing equation to use

    var scrollY = window.scrollY || document.documentElement.scrollTop,
        scrollTargetY = scrollTargetY || 0,
        speed = speed || 2000,
        easing = easing || 'easeOutSine',
        currentTime = 0;

    // min time .1, max time .8 seconds
    var time = Math.max(.1, Math.min(Math.abs(scrollY - scrollTargetY) / speed, .8));

    // easing equations from https://github.com/danro/easing-js/blob/master/easing.js
    var easingEquations = {
            easeOutSine: function (pos) {
                return Math.sin(pos * (Math.PI / 2));
            },
            easeInOutSine: function (pos) {
                return (-0.5 * (Math.cos(Math.PI * pos) - 1));
            },
            easeInOutQuint: function (pos) {
                if ((pos /= 0.5) < 1) {
                    return 0.5 * Math.pow(pos, 5);
                }
                return 0.5 * (Math.pow((pos - 2), 5) + 2);
            }
        };

    // add animation loop
    function tick() {
        currentTime += 1 / 60;

        var p = currentTime / time;
        var t = easingEquations[easing](p);

        if (p < 1) {
            requestAnimFrame(tick);

            window.scrollTo(0, scrollY + ((scrollTargetY - scrollY) * t));
        } else {
            console.log('scroll done');
            window.scrollTo(0, scrollTargetY);
        }
    }

    // call it once to get started
    tick();
}

// scroll it!
scrollToY(0, 1500, 'easeInOutQuint');
shunryu111
sumber
10
Senang seseorang menggunakanrequestAnimationFrame
Lucas
4
Harus dipilih dan dipilih sebagai jawabannya. Ini adalah satu-satunya yang berfungsi lintas browser
wlingke
requestAnimationFrametidak kompatibel dengan semua peramban secara spsly di beberapa ponsel, jadi ini bukan solusi yang dinamis, lihat: developer.mozilla.org/en-US/docs/Web/API/window/…
SUB-HDR
1
@ SUB-HDR di bagian atas cuplikan ada shim untuk requestAnimationFrameyang harus mengurus semua ketidakcocokan browser
shunryu111
Animasi menjadi sangat lamban ketika halaman memiliki bagian dengan banyak gambar di Firefox stackoverflow.com/questions/56396100/…
user3476614
79
window.scroll({top: 0, left: 0, behavior: 'smooth' });

Dapatkan dari artikel tentang Smooth Scrolling .

Jika diperlukan, ada beberapa polyfill yang tersedia.

Mihai Răducanu
sumber
4
Hampir kalah karena saya pikir ini adalah solusi jQuery. Artikel itu dikategorikan secara membingungkan! Juga, saya ingin menunjukkan yang scrollIntoView({behavior: 'smooth'})ada juga, dan dapat melakukan apa yang orang butuhkan untuk masalah seperti ini.
Brendan
1
Ini menimbulkan kesalahan pada Chrome terbaruUncaught TypeError: Failed to execute 'scroll' on 'Window': No function was found that matched the signature provided.
rorymorris89
1
@ Skgn dapat mengkonfirmasi ini sekarang sudah diperbaiki. Pembaruan Chrome lawas yang baik melanggar hal-hal :)
rorymorris89
4
Saya tidak tahu mengapa ini tidak memiliki lebih banyak suara, gulir sederhana ke atas tanpa 100000 baris kode! Terima kasih!
Smokey Dawson
4
Jawaban ini harus ditandai sebagai yang diterima. Pendekatan bawaan tanpa menggunakan fungsi transisi khusus, mengapa tidak !? Terima kasih!
Sagar
70

Saya memodifikasi jawaban TimWolla untuk menggunakan kuadrat pelonggaran (sedikit lebih lancar :). Berikut adalah contoh aksi: di jsFiddle . Fungsi pelonggaran tersedia di sini: Fungsi Pelonggaran Robert Penner

document.getElementsByTagName('button')[0].onclick = function () {
    scrollTo(document.body, 0, 1250);   
}

function scrollTo(element, to, duration) {
    var start = element.scrollTop,
        change = to - start,
        increment = 20;

    var animateScroll = function(elapsedTime) {        
        elapsedTime += increment;
        var position = easeInOut(elapsedTime, start, change, duration);                        
        element.scrollTop = position; 
        if (elapsedTime < duration) {
            setTimeout(function() {
                animateScroll(elapsedTime);
            }, increment);
        }
    };

    animateScroll(0);
}

function easeInOut(currentTime, start, change, duration) {
    currentTime /= duration / 2;
    if (currentTime < 1) {
        return change / 2 * currentTime * currentTime + start;
    }
    currentTime -= 1;
    return -change / 2 * (currentTime * (currentTime - 2) - 1) + start;
}
akai
sumber
5
Kode Anda tidak berfungsi di firefox. Apakah ada solusi untuk ini?
Milos
2
@ Milos Cukup gunakan "scrollTo (document.documentElement, 0, 1250);" alih-alih "scrollTo (document.body, 0, 1250);" dan itu harus berfungsi baik di Firefox maupun Chrome.
Daniel
Mengapa Anda menggunakan Matematika? Tanpa Matematika itu berfungsi demo
bCliks
2
@Aniel document. documentElementtidak berfungsi di Chrome.
bersumpah
@ bCliks, ini adalah metode pelonggaran
Clayton Graul
27

Tanpa kode JQuery, Semoga ini bisa membantu Anda.

function TopscrollTo() {
if(window.scrollY!=0)
{
    setTimeout(function() {
       window.scrollTo(0,window.scrollY-30);
        TopscrollTo();
    }, 100);
   }
}

panggil fungsi TopscrollTo () ini pada acara klik tombol atau pada elemen / acara lain yang Anda inginkan.

Vishal Patel
sumber
19

Saya memodifikasi kode @TimWolla untuk menambahkan lebih banyak opsi dan beberapa fungsi gerakan. Juga, menambahkan dukungan ke crossbrowser dengan document.body.scrollTop dan document.documentElement.scrollTop

// scroll to top
scrollTo(0, 1000);

// Element to move, time in ms to animate
function scrollTo(element, duration) {
    var e = document.documentElement;
    if(e.scrollTop===0){
        var t = e.scrollTop;
        ++e.scrollTop;
        e = t+1===e.scrollTop--?e:document.body;
    }
    scrollToC(e, e.scrollTop, element, duration);
}

// Element to move, element or px from, element or px to, time in ms to animate
function scrollToC(element, from, to, duration) {
    if (duration <= 0) return;
    if(typeof from === "object")from=from.offsetTop;
    if(typeof to === "object")to=to.offsetTop;

    scrollToX(element, from, to, 0, 1/duration, 20, easeOutCuaic);
}

function scrollToX(element, xFrom, xTo, t01, speed, step, motion) {
    if (t01 < 0 || t01 > 1 || speed<= 0) {
        element.scrollTop = xTo;
        return;
    }
    element.scrollTop = xFrom - (xFrom - xTo) * motion(t01);
    t01 += speed * step;

    setTimeout(function() {
        scrollToX(element, xFrom, xTo, t01, speed, step, motion);
    }, step);
}
function easeOutCuaic(t){
    t--;
    return t*t*t+1;
}

http://jsfiddle.net/forestrf/tPQSv/

Versi yang diperkecil: http://jsfiddle.net/forestrf/tPQSv/139/

// c = element to scroll to or top position in pixels
// e = duration of the scroll in ms, time scrolling
// d = (optative) ease function. Default easeOutCuaic
function scrollTo(c,e,d){d||(d=easeOutCuaic);var a=document.documentElement;if(0===a.scrollTop){var b=a.scrollTop;++a.scrollTop;a=b+1===a.scrollTop--?a:document.body}b=a.scrollTop;0>=e||("object"===typeof b&&(b=b.offsetTop),"object"===typeof c&&(c=c.offsetTop),function(a,b,c,f,d,e,h){function g(){0>f||1<f||0>=d?a.scrollTop=c:(a.scrollTop=b-(b-c)*h(f),f+=d*e,setTimeout(g,e))}g()}(a,b,c,0,1/e,20,d))};
function easeOutCuaic(t){
    t--;
    return t*t*t+1;
}
Forestrf
sumber
Dan apa gunanya melakukan 1 / durationketika Anda memanggil scrollToX untuk pertama kalinya?
Jessica
t01 adalah waktu yang bertambah dari 0 menjadi 1. Jika mencapai 1, croll berakhir. Saya melakukan ini 2 tahun yang lalu, saya tidak ingat semuanya, maaf.
Forestrf
11

Sebenarnya ada cara javascript murni untuk mencapai ini tanpa menggunakan setTimeoutataurequestAnimationFrame atau jQuery.

Singkatnya, cari elemen di scrollView yang ingin Anda gulir, dan gunakan scrollIntoView

el.scrollIntoView({behavior:"smooth"});

Ini adalah sebuah plunkr .

Jon
sumber
Jawaban terbaik: satu baris kode, yang terpendek dan efektif;)
Jacopo Pace
1
Perhatikan bahwa melewatinya scrollIntoViewOptiontidak memiliki dukungan lintas browser. developer.mozilla.org/en-US/docs/Web/API/Element/scrollIntoView
WebWanderer
9

Diadaptasi dari jawaban ini :

function scroll(y, duration) {

    var initialY = document.documentElement.scrollTop || document.body.scrollTop;
    var baseY = (initialY + y) * 0.5;
    var difference = initialY - baseY;
    var startTime = performance.now();

    function step() {
        var normalizedTime = (performance.now() - startTime) / duration;
        if (normalizedTime > 1) normalizedTime = 1;

        window.scrollTo(0, baseY + difference * Math.cos(normalizedTime * Math.PI));
        if (normalizedTime < 1) window.requestAnimationFrame(step);
    }
    window.requestAnimationFrame(step);
}

Ini akan memungkinkan Anda untuk menggulir dengan lancar (fungsi cosinus) dari mana saja ke "y" yang ditentukan.

Raslanove
sumber
9

Tidak ada yang menyebutkan perilaku gulir properti CSS

CSS

html {
  scroll-behavior: smooth;
}

JS

window.scrollTo(0,0)
Fangxing
sumber
Ini luar biasa! Tidak didukung di semua browser, tapi tidak apa-apa karena itu kembali dengan baik.
Swimburger
Astaga, di mana semua ini selama hidupku?
Mitya
8

KURANGI GELAS SEKOLAH JAVASCRIPT

Ini adalah pertanyaan lama tapi saya pikir saya bisa menjawab dengan beberapa hal mewah dan beberapa opsi untuk dimainkan jika Anda ingin memiliki kontrol lebih besar atas animasi.

  • Lintas browser
  • Salin / Rekatkan solusi siap (Anda hanya perlu CSS dan JS)
  • 3 mode bernyawa: ["normal" | "linear" | false]
  • Kustomisasi animasi Anda dengan pengaturan yang tersedia - buat itu cepat atau lancar
  • Klik dua kali untuk melewati animasi
  • Setiap klik berikutnya menambah kecepatan awal
  • Hentikan animasi gulir dengan menurunkan bilah gulir
  • Hentikan animasi gulir dengan roda mouse ke bawah
  • Tombol animasi fade-in-out pada gulir
  • Ini dia JS Class murni untuk menangani pengguliran untuk Anda:

    MELIHAT DEMO DI CODEPEN ATAU PERGI KE BOTTOM DAN JALANKAN SINPET

    // ------------------- USE EXAMPLE ---------------------
    // *Set options
    var options = {
      'showButtonAfter': 200, // show button after scroling down this amount of px
      'animate': "linear", // [false|normal|linear] - for false no aditional settings are needed
    
      'normal': { // applys only if [animate: normal] - set scroll loop distanceLeft/steps|ms
        'steps': 20, // the more steps per loop the slower animation gets
        'ms': 10 // the less ms the quicker your animation gets
      }, 
      'linear': { // applys only if [animate: linear] - set scroll px|ms
        'px': 30, // the more px the quicker your animation gets
        'ms': 10 // the less ms the quicker your animation gets
      }, 
    };
    
    
    // *Create new Scroller and run it.
    var scroll = new Scroller(options);
    scroll.init();

    SCRIPT KELAS LENGKAP + GUNAKAN CONTOH:

    // PURE JAVASCRIPT (OOP)
    
    function Scroller(options) {
      this.options = options;
      this.button = null;
      this.stop = false;
    }
    
    Scroller.prototype.constructor = Scroller;
    
    Scroller.prototype.createButton = function() {
    
      this.button = document.createElement('button');
      this.button.classList.add('scroll-button');
      this.button.classList.add('scroll-button--hidden');
      this.button.textContent = "^";
      document.body.appendChild(this.button);
    }
    
    Scroller.prototype.init = function() {
      this.createButton();
      this.checkPosition();
      this.click();
      this.stopListener();
    }
    
    Scroller.prototype.scroll = function() {
      if (this.options.animate == false || this.options.animate == "false") {
        this.scrollNoAnimate();
        return;
      }
      if (this.options.animate == "normal") {
        this.scrollAnimate();
        return;
      }
      if (this.options.animate == "linear") {
        this.scrollAnimateLinear();
        return;
      }
    }
    Scroller.prototype.scrollNoAnimate = function() {
      document.body.scrollTop = 0;
      document.documentElement.scrollTop = 0;
    }
    Scroller.prototype.scrollAnimate = function() {
      if (this.scrollTop() > 0 && this.stop == false) {
        setTimeout(function() {
          this.scrollAnimate();
          window.scrollBy(0, (-Math.abs(this.scrollTop()) / this.options.normal['steps']));
        }.bind(this), (this.options.normal['ms']));
      }
    }
    Scroller.prototype.scrollAnimateLinear = function() {
      if (this.scrollTop() > 0 && this.stop == false) {
        setTimeout(function() {
          this.scrollAnimateLinear();
          window.scrollBy(0, -Math.abs(this.options.linear['px']));
        }.bind(this), this.options.linear['ms']);
      }
    }
    
    Scroller.prototype.click = function() {
    
      this.button.addEventListener("click", function(e) {
        e.stopPropagation();
        this.scroll();
      }.bind(this), false);
    
      this.button.addEventListener("dblclick", function(e) {
        e.stopPropagation();
        this.scrollNoAnimate();
      }.bind(this), false);
    
    }
    
    Scroller.prototype.hide = function() {
      this.button.classList.add("scroll-button--hidden");
    }
    
    Scroller.prototype.show = function() {
      this.button.classList.remove("scroll-button--hidden");
    }
    
    Scroller.prototype.checkPosition = function() {
      window.addEventListener("scroll", function(e) {
        if (this.scrollTop() > this.options.showButtonAfter) {
          this.show();
        } else {
          this.hide();
        }
      }.bind(this), false);
    }
    
    Scroller.prototype.stopListener = function() {
    
      // stop animation on slider drag
      var position = this.scrollTop();
      window.addEventListener("scroll", function(e) {
        if (this.scrollTop() > position) {
          this.stopTimeout(200);
        } else {
          //...
        }
        position = this.scrollTop();
      }.bind(this, position), false);
    
      // stop animation on wheel scroll down
      window.addEventListener("wheel", function(e) {
        if (e.deltaY > 0) this.stopTimeout(200);
      }.bind(this), false);
    }
    
    Scroller.prototype.stopTimeout = function(ms) {
      this.stop = true;
      // console.log(this.stop); //
      setTimeout(function() {
        this.stop = false;
        console.log(this.stop); //
      }.bind(this), ms);
    }
    
    Scroller.prototype.scrollTop = function() {
      var curentScrollTop = document.documentElement.scrollTop || document.body.scrollTop;
      return curentScrollTop;
    }
    
    
    
    // ------------------- USE EXAMPLE ---------------------
    // *Set options
    var options = {
      'showButtonAfter': 200, // show button after scroling down this amount of px
      'animate': "normal", // [false|normal|linear] - for false no aditional settings are needed
    
      'normal': { // applys only if [animate: normal] - set scroll loop distanceLeft/steps|ms
        'steps': 20, // the more steps per loop the slower animation gets
        'ms': 10 // the less ms the quicker your animation gets
      },
      'linear': { // applys only if [animate: linear] - set scroll px|ms
        'px': 30, // the more px the quicker your animation gets
        'ms': 10 // the less ms the quicker your animation gets
      },
    };
    // *Create new Scroller and run it.
    var scroll = new Scroller(options);
    scroll.init();
    /* CSS */
    
    @import url(https://fonts.googleapis.com/css?family=Open+Sans);
     body {
      font-family: 'Open Sans', sans-serif;
      font-size: 1.2rem;
      line-height: 2rem;
      height: 100%;
      position: relative;
      padding: 0 25%;
    }
    .scroll-button {
      font-size: 1.2rem;
      line-height: 2rem;
      padding: 10px;
      width: 50px;
      height: 50px;
      background: black;
      color: white;
      border-radius: 50%;
      position: fixed;
      right: 20px;
      bottom: 20px;
      visibility: visible;
      filter: alpha(opacity=50);
      filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=50);
      opacity: 0.5;
      cursor: pointer;
      transition: all 1.2s;
      -webkit-transition: all 1.2s;
      -moz-transition: all 1.2s;
      -ms-transition: all 1.2s;
      -o-transition: all 1.2s;
    }
    .scroll-button:hover {
      filter: alpha(opacity=100);
      filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=100);
      opacity: 1;
    }
    .scroll-button--hidden {
      filter: alpha(opacity=0);
      filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=0);
      opacity: 0;
      visibility: hidden;
    }
    <!-- HTML -->
    
    <h1>Scroll down by 200px for button to appear</h1>
    <ul>
      <li>Cross-browser</li>
      <li>Copy/Paste solution</li>
      <li>3 animate modes: <b>["normal"|"linear"|false]</b></li>
      <li>Customize your aniamtion with aveilable settings - make it snapy or fluent</li>
      <li>Double click to skip animation</li>
      <li>Every next single click adds initial speed</li>
      <li>Stop scroll animation by draging down the scroll bar</li>
      <li>Stop scroll animation by mouse wheel down</li>
      <li>Animated button fade-in-out on scroll</li>
    </ul>
    
    <br />
    <br />
    <pre>
    // ------------------- USE EXAMPLE ---------------------
    // *Set options
    var options = {
      'showButtonAfter': 200, // show button after scroling down this amount of px
      'animate': "normal", // [false|normal|linear] - for false no aditional settings are needed
      
      'normal': { // applys only if [animate: normal] - set scroll loop distanceLeft/steps|ms
        'steps': 20, // the more steps the slower animation gets
        'ms': 20 // the less ms the quicker your animation gets
      }, 
      'linear': { // applys only if [animate: linear] - set scroll px|ms
        'px': 55, // the more px the quicker your animation gets
        'ms': 10 // the less ms the quicker your animation gets
      }, 
    };
    
    // *Create new Scroller and run it.
    var scroll = new Scroller(options);
    scroll.init();
    </pre>
    <br />
    <br />
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quae molestiae illo nobis quo autem molestias voluptatum quam, amet ipsum debitis, iure animi illum soluta eaque qui perspiciatis harum, sequi nesciunt.</span><span>Quisquam nesciunt aspernatur a possimus pariatur enim architecto. Hic aperiam sit repellat doloremque vel est soluta et assumenda dolore, sint sapiente porro, quam impedit. Sint praesentium quas excepturi, voluptatem dicta!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptate, porro nisi molestias minima corrupti tempore, dolorum fugiat ipsam dicta doloremque accusamus atque consequatur iusto natus, mollitia distinctio odit dolor tempora.</span><span>Perferendis a in laudantium accusantium, dolorum eius placeat velit porro similique, eum cumque veniam neque aspernatur architecto suscipit rem laboriosam voluptates laborum? Voluptates tempora necessitatibus animi nostrum quod, maxime odio.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nihil accusantium, itaque corporis repellat pariatur soluta officia perspiciatis in reprehenderit facere, incidunt saepe excepturi. Inventore atque ex illo, ipsam at deserunt.</span><span>Laborum inventore officia, perspiciatis cumque magni consequatur iste accusantium soluta, nesciunt blanditiis voluptatibus adipisci laudantium mollitia minus quia necessitatibus voluptates. Minima unde quos impedit necessitatibus aspernatur minus maiores ipsa eligendi!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptate nesciunt, explicabo similique, quo maxime modi, aliquid, voluptatibus repellendus dolorum placeat mollitia ea dicta quia laboriosam alias dignissimos ipsam tenetur. Nulla.</span><span>Vel maiores necessitatibus odio voluptate debitis, error in accusamus nulla, eum, nemo et ea commodi. Autem numquam at, consequatur temporibus. Mollitia placeat nobis blanditiis impedit distinctio! Ad, incidunt fugiat sed.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ipsam voluptatum, odio quam omnis iste laudantium, itaque architecto, eos ullam debitis delectus sapiente nemo autem reprehenderit. Dolorem quidem facere ipsam! Nisi.</span><span>Vitae quaerat modi voluptatibus ratione numquam? Sapiente aliquid officia pariatur quibusdam aliquam id expedita non recusandae, cumque deserunt asperiores. Corrupti et doloribus aspernatur ipsum asperiores, ipsa unde corporis commodi reiciendis?</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Minima adipisci minus iste, nesciunt itaque quisquam quidem voluptatum assumenda rerum aliquid, excepturi voluptatem tempora. Possimus ratione alias a error vel, rem.</span><span>Officia esse error accusantium veritatis ad, et sit animi? Recusandae mollitia odit tenetur ad cumque maiores eligendi blanditiis nobis hic tempora obcaecati consequatur commodi totam, debitis, veniam, ducimus molestias ut.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Obcaecati quibusdam, tempora cupiditate quaerat tempore ullam delectus voluptates optio eum placeat provident consequatur iure reprehenderit vero quae sapiente architecto earum nemo.</span><span>Quis molestias sint fuga doloribus, necessitatibus nulla. Esse ipsa, itaque asperiores. Tempora a sequi nobis cumque incidunt aspernatur, pariatur rem voluptatibus. Atque veniam magnam, ea laudantium ipsum reprehenderit sapiente repellendus.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Minima, pariatur at explicabo aliquid repudiandae vero eum quasi totam voluptates iusto unde ad repellendus ipsam et voluptatem hic adipisci! Vero, nobis!</span><span>Consequatur eligendi quo quas omnis architecto dolorum aperiam doloremque labore, explicabo enim incidunt vitae saepe, quod soluta illo odit provident amet beatae quasi animi. Similique nostrum molestiae animi corrupti qui?</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Molestias quis, tempora laborum incidunt qui fuga adipisci doloremque iusto commodi vitae est, nemo iure placeat ut sit optio, consequuntur voluptas impedit.</span><span>Eos officiis, hic esse unde eaque, aut tenetur voluptate quam sint vel exercitationem totam dolor odio soluta illo praesentium non corrupti! Consequuntur velit, mollitia excepturi. Minus, veniam accusantium! Aliquam, ea!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Reprehenderit quis reiciendis veritatis expedita velit vitae amet magni sunt rerum in blanditiis aut tempore quia fugiat, voluptates officia quaerat quam id.</span><span>Sapiente tempore repudiandae, quae doloremque ullam odio quia ea! Impedit atque, ipsa consequatur quis obcaecati voluptas necessitatibus, cupiditate sunt amet ab modi illum inventore, a dolor enim similique architecto est!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Itaque non aliquam, sit illo quas deserunt esse nobis reprehenderit quidem fuga beatae eligendi reiciendis omnis qui repellat velit earum blanditiis possimus.</span><span>Provident aspernatur ducimus, illum beatae debitis vitae non dolorum rem officia nostrum natus accusantium perspiciatis ad soluta maiores praesentium eveniet qui hic quis at quaerat ea perferendis. Ut, aut, natus.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ratione corrupti quibusdam, sed hic veniam. Perspiciatis ex, quod architecto natus autem totam at commodi excepturi maxime pariatur corporis, veritatis vero, praesentium.</span><span>Nesciunt suscipit, nobis eos perferendis ex quaerat inventore nihil qui magnam saepe rerum velit reiciendis ipsam deleniti ducimus eligendi odio eius minima vero, nisi voluptates amet eaque, iste, labore laudantium.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Illo, voluptas accusantium ad omnis velit distinctio! Adipisci magnam nihil nostrum molestiae rem dolores, ut ad nemo, dolor quos itaque maiores quaerat!</span><span>Quia ad suscipit reprehenderit vitae inventore eius non culpa maiores omnis sit obcaecati vel placeat quibusdam, ipsa exercitationem nam odit, magni nobis. Quam quas, accusamus expedita molestiae asperiores eaque ex?</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rerum explicabo doloribus nihil iusto quasi vel expedita dignissimos amet mollitia, temporibus aut atque architecto assumenda dolorum nam velit deserunt totam numquam.</span><span>Ab perferendis labore, quae. Quidem architecto quo officia deserunt ea doloribus libero molestias id nisi perferendis eum porro, quibusdam! Odit aliquid placeat rem aut officia minus sit esse eos obcaecati!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Eligendi nostrum repellendus placeat, unde aperiam. Fuga, voluptas, minima. Debitis nemo ducimus itaque laboriosam error quaerat reprehenderit quo animi incidunt. Nulla, quis!</span><span>Explicabo assumenda dicta ratione? Tempora commodi asperiores, explicabo doloremque eius quia impedit possimus architecto sit nemo odio eum fuga minima dolor iste mollitia sequi dolorem perspiciatis unde quisquam laborum soluta.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Veniam officia corporis, reiciendis laudantium, voluptate voluptates necessitatibus assumenda, delectus quisquam velit deserunt! Reprehenderit, vel quaerat accusantium nesciunt libero animi. Sequi, eveniet?</span><span>Animi natus pariatur porro, alias, veniam aut est tempora adipisci molestias harum modi cumque assumenda enim! Expedita eveniet autem illum rerum nostrum ipsum alias neque aut, dolorum impedit pariatur non?</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quis aliquid rerum, odio veniam ipsam ad officia quos repellat ex aperiam voluptatum optio est animi possimus minus. Sapiente voluptates amet dolorem.</span><span>Illo necessitatibus similique asperiores inventore ut cumque nihil assumenda debitis explicabo rerum, dolorum molestiae culpa accusantium. Nisi doloremque optio provident blanditiis, eum ipsam asperiores, consequatur aliquam vel sit mollitia sunt.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Enim, totam harum perferendis. Minus ea perferendis laboriosam, iste, qui corrupti, quas veritatis omnis officiis animi fuga perspiciatis impedit! Error, harum, voluptas.</span><span>Omnis laborum, cum mollitia facilis ipsa unde distinctio maxime nesciunt illum perspiciatis ut officiis, eligendi numquam dolorem quod modi ipsam est rerum perferendis repellendus totam. Maxime excepturi culpa alias labore.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Impedit deleniti, odit sit consequatur dolorum omnis repellendus, alias vel ullam numquam. Nostrum obcaecati hic, possimus delectus nam atque aliquid explicabo cum.</span><span>Explicabo tenetur minima consequatur, aliquam, laudantium non consequuntur facilis sint, suscipit debitis ex atque mollitia magni quod repellat ratione dolorum excepturi molestiae cumque iusto eos unde? Voluptatum dolores, porro provident!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. At laboriosam fuga aperiam eveniet, obcaecati esse, nulla porro iure molestiae praesentium sint fugiat ea voluptate suscipit voluptates mollitia, voluptatibus. Autem, non.</span><span>Numquam velit culpa tempora ratione ipsum minus modi in? Nisi reiciendis, voluptate voluptatem maxime repellat quae odio, repellendus aliquid laborum dolorem. Labore, fuga ea minima explicabo quae voluptatum necessitatibus, similique.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quasi, rerum dolorum nemo error fugiat ut, modi, architecto libero maxime laborum repellendus doloribus neque aperiam adipisci quaerat obcaecati deserunt consequuntur amet!</span><span>Sint, assumenda nisi obcaecati doloremque iste. Perspiciatis accusantium, distinctio impedit cum esse recusandae sunt. Officiis culpa dolore eius, doloribus natus, dolorum excepturi vitae fugiat ullam provident harum! Suscipit, assumenda, harum.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Odit, nihil tenetur tempore eligendi qui nesciunt consequatur delectus accusantium consectetur ipsa, nulla doloribus dolores rerum corporis, laborum, laboriosam hic mollitia repellat.</span><span>Ab deleniti vitae blanditiis quod tenetur! Voluptatem temporibus ab eaque quis? Quis odio aliquid harum temporibus totam, ipsa eius iusto fugiat enim in, quibusdam molestiae aliquam consequatur nulla, consequuntur sint.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Illum odit praesentium quos, earum nesciunt laudantium illo tempora eligendi, porro doloremque mollitia neque aperiam inventore nam maxime dolor labore aspernatur molestias.</span><span>Voluptatibus provident hic cupiditate placeat, ut reprehenderit nisi eum, dolores ad sed quis. Doloribus molestiae, quae rem odit expedita soluta, facilis animi corporis velit ut in, recusandae harum laboriosam veritatis.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Incidunt repudiandae molestias magnam delectus veritatis labore, corporis dicta officia quos, ad corrupti odit! Ad hic officia maxime eveniet consectetur similique adipisci!</span><span>Quia at, nesciunt aliquid delectus ex alias voluptas maxime hic esse. Incidunt, laborum quos mollitia dolores et! Voluptas commodi asperiores, fugit quidem quis corporis, a eaque, animi, autem deserunt repellendus.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Sequi quas, voluptas hic minima inventore optio, id quidem placeat necessitatibus omnis voluptatibus vitae mollitia tempora consequuntur consequatur, illo facilis accusamus illum.</span><span>Voluptates consequuntur ipsam odit. Eius quis ipsam vitae, nihil molestias perferendis corporis recusandae consequatur vero iure blanditiis quas adipisci quos voluptatem rem illo voluptate. Eveniet officiis iure sit laborum veniam.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Suscipit a quis cumque nostrum quisquam molestiae pariatur, asperiores natus necessitatibus adipisci illum cupiditate nam vero, tempora excepturi laborum, earum. Voluptates, nobis.</span><span>Pariatur suscipit, hic blanditiis libero, iusto, quam cupiditate nam error id asperiores repellat ab consequatur vitae ipsa voluptatem totam magni reiciendis expedita maxime dolor! Minus explicabo quas, laborum ab omnis!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Labore qui ad assumenda placeat optio illo molestias corporis dolorum cum. Doloribus eius autem obcaecati minima, asperiores iure dignissimos ducimus suscipit dolorem.</span><span>Blanditiis earum accusamus eaque temporibus necessitatibus voluptatum dolorem enim debitis inventore assumenda quae error perspiciatis aut, nulla delectus quam ipsa sapiente ea aliquam laboriosam repudiandae. Nesciunt praesentium, beatae eos quasi!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Cupiditate dicta voluptate impedit? Ad voluptatum dicta earum perferendis asperiores. Dolore distinctio modi expedita consequatur provident perspiciatis neque totam rerum placeat quas.</span><span>Eveniet optio est possimus iste accusantium ipsum illum. Maiores saepe repudiandae facere, delectus iure dolorem vitae nihil pariatur minima, reprehenderit eligendi dolore impedit, nisi doloribus quidem similique. Optio, delectus, minus.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Iste ex molestiae architecto enim nihil tempore, atque consequuntur doloribus recusandae sed consequatur veniam quos, in consectetur perspiciatis magni nostrum ab voluptates.</span><span>Nisi quos mollitia quis in maiores asperiores labore deserunt! Voluptate voluptas adipisci qui hic officia molestias, laborum necessitatibus sint nam vel minus incidunt perspiciatis recusandae sunt, rerum suscipit doloremque possimus!</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. At nihil perferendis quae quidem facilis aliquid pariatur possimus hic asperiores, recusandae exercitationem adipisci atque laborum, delectus, odit ab reprehenderit distinctio dolor.</span><span>Non excepturi quos aspernatur repudiandae laboriosam, unde molestias, totam, sapiente harum accusamus delectus laborum ipsam velit amet nisi! Consectetur aliquam provident voluptatibus saepe repudiandae eveniet laborum beatae, animi, voluptate dolores.</span></p>
    <p><span>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Cumque magni, eum ipsa, veritatis facere voluptatem dolorum nobis neque minus debitis asperiores iste. Pariatur sequi quam, tempora. Dignissimos, esse similique tempora.</span><span>Ex delectus excepturi autem sunt, nemo repudiandae, recusandae nostrum accusantium nobis temporibus magnam eligendi similique veritatis deleniti, eaque blanditiis possimus at! Repellat alias laboriosam ipsum commodi dolorem, corporis dolore suscipit!</span></p>

    DevWL
    sumber
    1
    Yah itu sangat sederhana jika Anda melihat lebih dekat. Mungkin OOP yang membuatnya terlihat sedikit lebih rumit dari yang sebenarnya. Cuplikan lainnya tidak akan mencakup pemutusan fungsionalitas gulir. Jadi saya memposting sesuatu yang sedikit lebih lengkap. Jika Anda tidak peduli tentang itu maka solusi saya dapat melihat sedikit di atas untuk kebutuhan Anda. Untuk membuatnya bekerja di FF dan IE, Anda hanya perlu menambahkan awalan untuk CSS. Saya akan memperbaikinya jika ada orang lain yang meminta untuk melakukannya. Saya menambahkan CSS karena saya ingin menjadikannya solusi "salin / tempel". Saya tidak berpikir ini bisa lebih mudah dari itu :-).
    DevWL
    Ok ini bukan masalah awalan :) tapi saya tetap akan memperbaikinya.
    DevWL
    Masalah terpecahkan. Sekarang akan berfungsi di IE, FF dan Chrome ... Inilah yang terjadi: "document.documentElement.scrollTop" Bekerja di Firefox dan IE tetapi tidak di Chrome, "document.body.scrollTop" berfungsi di Chrome tetapi tidak di Firefox dan tidak di IE. Untuk memperbaiki masalah metode baru [scrollTop ()] diimplementasikan ke prototipe kelas. Metode baru mengembalikan nilai dari browser yang berfungsi: // var curentScrollTop = document.documentElement.scrollTop || document.body.scrollTop; // kembalikan curentScrollTop;
    DevWL
    Bug IE lainnya diperbaiki. classList.add ('class1, class2'); hanya akan menerapkan class1, class2 akan diabaikan,. Perbaiki: classList.add ('class1'); classList.add ('class2'); Tombol Sekarang disembunyikan saat memuat IE.
    DevWL
    6

    Mudah.

    var scrollIt = function(time) {
        // time = scroll time in ms
        var start = new Date().getTime(),
            scroll = document.documentElement.scrollTop + document.body.scrollTop,
            timer = setInterval(function() {
                var now = Math.min(time,(new Date().getTime())-start)/time;
                document.documentElement.scrollTop
                    = document.body.scrollTop = (1-time)/start*scroll;
                if( now == 1) clearTimeout(timer);
            },25);
    }
    Niet the Dark Absol
    sumber
    Atau adil window.scrollTo(x, y);.
    Rob W
    3
    Itu tidak menghidupkannya sekalipun.
    Niet the Dark Absol
    Saya menawarkan opsi alternatif untuk .scrollTopdan .scrollLeft.
    Rob W
    @NiettheDarkAbsol Ini hanya Fungsi yang peduli tentang body.scrolltop dan documentElement.scrolltop. tetapi ada beberapa kesalahan seperti scroll tidak pernah menggunakan, miss semi colon dll. Bisakah Anda merevisinya.
    Deniz Porsuk
    @ DenizPorsuk Anda benar tentang "gulir tidak digunakan", seharusnya *scrollketika menghitung posisi gulir. Namun, saya tidak melihat ada yang hilang ;...
    Niet the Dark Absol
    2

    Baru saja membuat solusi javascript ini di bawah ini.

    Penggunaan sederhana:

    EPPZScrollTo.scrollVerticalToElementById('wrapper', 0);

    Objek mesin (Anda dapat mengutak-atik filter, nilai fps):

    /**
     *
     * Created by Borbás Geri on 12/17/13
     * Copyright (c) 2013 eppz! development, LLC.
     *
     * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
     * The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
     * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
     *
     */
    
    
    var EPPZScrollTo =
    {
        /**
         * Helpers.
         */
        documentVerticalScrollPosition: function()
        {
            if (self.pageYOffset) return self.pageYOffset; // Firefox, Chrome, Opera, Safari.
            if (document.documentElement && document.documentElement.scrollTop) return document.documentElement.scrollTop; // Internet Explorer 6 (standards mode).
            if (document.body.scrollTop) return document.body.scrollTop; // Internet Explorer 6, 7 and 8.
            return 0; // None of the above.
        },
    
        viewportHeight: function()
        { return (document.compatMode === "CSS1Compat") ? document.documentElement.clientHeight : document.body.clientHeight; },
    
        documentHeight: function()
        { return (document.height !== undefined) ? document.height : document.body.offsetHeight; },
    
        documentMaximumScrollPosition: function()
        { return this.documentHeight() - this.viewportHeight(); },
    
        elementVerticalClientPositionById: function(id)
        {
            var element = document.getElementById(id);
            var rectangle = element.getBoundingClientRect();
            return rectangle.top;
        },
    
        /**
         * Animation tick.
         */
        scrollVerticalTickToPosition: function(currentPosition, targetPosition)
        {
            var filter = 0.2;
            var fps = 60;
            var difference = parseFloat(targetPosition) - parseFloat(currentPosition);
    
            // Snap, then stop if arrived.
            var arrived = (Math.abs(difference) <= 0.5);
            if (arrived)
            {
                // Apply target.
                scrollTo(0.0, targetPosition);
                return;
            }
    
            // Filtered position.
            currentPosition = (parseFloat(currentPosition) * (1.0 - filter)) + (parseFloat(targetPosition) * filter);
    
            // Apply target.
            scrollTo(0.0, Math.round(currentPosition));
    
            // Schedule next tick.
            setTimeout("EPPZScrollTo.scrollVerticalTickToPosition("+currentPosition+", "+targetPosition+")", (1000 / fps));
        },
    
        /**
         * For public use.
         *
         * @param id The id of the element to scroll to.
         * @param padding Top padding to apply above element.
         */
        scrollVerticalToElementById: function(id, padding)
        {
            var element = document.getElementById(id);
            if (element == null)
            {
                console.warn('Cannot find element with id \''+id+'\'.');
                return;
            }
    
            var targetPosition = this.documentVerticalScrollPosition() + this.elementVerticalClientPositionById(id) - padding;
            var currentPosition = this.documentVerticalScrollPosition();
    
            // Clamp.
            var maximumScrollPosition = this.documentMaximumScrollPosition();
            if (targetPosition > maximumScrollPosition) targetPosition = maximumScrollPosition;
    
            // Start animation.
            this.scrollVerticalTickToPosition(currentPosition, targetPosition);
        }
    };
    Geri Borbás
    sumber
    8
    Benarkah? Membuat sepotong kode mengerikan ini seperti menggunakan peluncur roket untuk membunuh seekor lalat.
    Killah
    3
    @Killah Saya sangat peduli tentang penggunaan yang sederhana, dan mudah dibaca saja. Saya dapat mempostingnya diperkecil jika Anda mau. :)
    Geri Borbás
    Yang ingin saya katakan adalah bahwa ada terlalu banyak fungsi pembantu di sana (mengapa Anda memerlukan fungsi pembantu yang digunakan sekali?), console.warnDan parameter string di setTimeouttidak cocok dalam kode produksi (yang kedua cukup banyak tidak cocok di mana saja, karena evalpada dasarnya).
    Killah
    1
    Dengan asumsi pemanggilan fungsi bukan hal yang mahal, saya lebih suka mengekstrak kode apa pun ke fungsi bernama daripada berkomentar segala sesuatu di sekitar. Jadi Anda (setidaknya saya) dapat membaca kode lebih baik, juga kode klien bisa menjadi sepuluh liner lebih pendek.
    Geri Borbás
    2

    Membangun beberapa jawaban di sini, tetapi menggunakan beberapa matematika sederhana untuk transisi yang lancar menggunakan kurva sinus:

    scrollTo(element, from, to, duration, currentTime) {
           if (from <= 0) { from = 0;}
           if (to <= 0) { to = 0;}
           if (currentTime>=duration) return;
           let delta = to-from;
           let progress = currentTime / duration * Math.PI / 2;
           let position = delta * (Math.sin(progress));
           setTimeout(() => {
               element.scrollTop = from + position;
               this.scrollTo(element, from, to, duration, currentTime + 10);
           }, 10);
       }

    Pemakaian:

    // Smoothly scroll from current position to new position in 1/2 second.
    scrollTo(element, element.scrollTop, element.scrollTop + 400, 500, 0);

    PS. perhatikan gaya ES6

    Sybrand
    sumber
    1

    Ini adalah pendekatan lintas browser berdasarkan jawaban di atas

    function scrollTo(to, duration) {
        if (duration < 0) return;
        var scrollTop = document.body.scrollTop + document.documentElement.scrollTop;
        var difference = to - scrollTop;
        var perTick = difference / duration * 10;
    
        setTimeout(function() {
          scrollTop = scrollTop + perTick;
          document.body.scrollTop = scrollTop;
          document.documentElement.scrollTop = scrollTop;
          if (scrollTop === to) return;
          scrollTo(to, duration - 10);
        }, 10);
      }
    Belchior Oliveira
    sumber
    Jawaban bagus! Bisakah Anda jelaskan apa yang terjadi dengan differencedan perTick?
    Jessica
    1

    Namun pendekatan lain menggunakan window.scrollBy

    JSFiddle

    function scroll(pxPerFrame, duration) {
            if (!pxPerFrame || !duration) return;
            const end = new Date().getTime() + duration;
            step(); 
    
            function step() {
              window.scrollBy(0, pxPerFrame);
              if (new Date().getTime() < end) {
                window.setTimeout(step, 1000 / 60);
              } else {
                console.log('done scrolling'); 
              }
            }
          }
    body {
      width: 200px;
    }
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
    <p>
    <button onclick="scroll(-5, 3000)">
    scroll(-5, 3000)
    </button>
    </p>

    remdevtec
    sumber
    1

    Saya telah memilih versi @timwolla jawab @akai dan menambahkan fungsi stopAnimation sebagai balasan, jadi sebelum memulai animasi baru, yang lama dapat dihentikan.

    if ( this.stopAnimation )
        this.stopAnimation()
    
        this.stopAnimation = scrollTo( el, scrollDestination, 300 )
    
    
    // definitions
    
    function scrollTo(element, to, duration) {
        var start = element.scrollTop,
            change = to - start,
            increment = 20,
            timeOut;
    
        var animateScroll = function(elapsedTime) {        
            elapsedTime += increment;
            var position = easeInOut(elapsedTime, start, change, duration);                        
            element.scrollTop = position; 
            if (elapsedTime < duration) {
                timeOut = setTimeout(function() {
                    animateScroll(elapsedTime);
                }, increment);
            }
        };
    
        animateScroll(0);
    
        return stopAnimation
    
        function stopAnimation() {
            clearTimeout( timeOut )
        }
    }
    
    function easeInOut(currentTime, start, change, duration) {
        currentTime /= duration / 2;
        if (currentTime < 1) {
            return change / 2 * currentTime * currentTime + start;
        }
        currentTime -= 1;
        return -change / 2 * (currentTime * (currentTime - 2) - 1) + start;
    }
    Luckylooke
    sumber
    0

    Pendekatan lintas browser lain berdasarkan pada solusi di atas

    function doScrollTo(to, duration) {
        var element = document.documentElement;
    
            var start = element.scrollTop,
            change = to - start,
            increment = 20,
            i = 0;
    
        var animateScroll = function(elapsedTime) {
            elapsedTime += increment;
            var position = easeInOut(elapsedTime, start, change, duration);
            if (i === 1 && window.scrollY === start) {
                element = document.body;
                start = element.scrollTop;
            }
            element.scrollTop = position;
            if (!i) i++;
            if (elapsedTime < duration) {
                setTimeout(function() {
                    animateScroll(elapsedTime);
                }, increment);
            }
        };
    
        animateScroll(0);
    }

    Caranya adalah mengontrol perubahan gulir yang sebenarnya, dan jika itu nol, ubah elemen gulir.

    Zdenek Hatak
    sumber
    -1

    Animasi bergulir linear ke bawah. JS murni, tanpa JQuery. Mungkin solusi saya akan membantu seseorang.

    let action_count = 8;
    let speed_ms = 15;
    let objDiv = document.getElementsByClassName('js_y5_area3').item(0);
    
    let scroll_height = objDiv.scrollHeight;
    let window_height = objDiv.offsetHeight;
    
    let scroll_top = objDiv.scrollTop;
    let need_scroll_top = scroll_height - window_height;
    
    if (scroll_top < need_scroll_top)
    {
        let step = Math.ceil((need_scroll_top - scroll_top) / action_count);
    
        let scrollInterval = setInterval(function()
        {
            scroll_top += step;
            objDiv.scrollTop = scroll_top;
    
            if (scroll_top >= need_scroll_top)
            {
                clearInterval(scrollInterval);
            }
    
        }, speed_ms);
    }

    Anda dapat mengubah variabel action_count, speed_msuntuk mengonfigurasi animasi gulir sesuai selera Anda.

    sNICkerssss
    sumber
    -2

    Gunakan solusi ini

    animate(document.documentElement, 'scrollTop', 0, 200);

    Terima kasih

    Lokesh Gamot
    sumber
    Sayangnya sepertinya ini bukan lintas-browser yang cerdas. :(
    Lucas Morgan
    @LucasMorgan Anda hanya perlu menemukan elemen dom yang benar untuk "document.documentElemen", Seperti apa pun yang cocok untuk Anda
    Lokesh Gamot
    1
    Kecuali ada animate()fungsi dalam lingkup jendela ... Saya pikir Anda salah paham. The Element.animate()Fungsi tidak diakui oleh banyak browser. Lihat developer.mozilla.org/en-US/docs/Web/API/Element/animate
    Lucas Morgan
    Yap saya salah paham. Anda berbicara tentang fungsi jquery. Saya berasumsi Anda tidak akan memunculkan jquery karena pertanyaannya tidak meminta jquery. Salahku!
    Lucas Morgan
    -3

    Saya melihat bahwa sebagian besar dari semua posting di atas mencari tombol dengan javascript. Ini berfungsi, selama Anda hanya memiliki satu tombol. Saya akan merekomendasikan mendefinisikan elemen "klik" di dalam tombol. "Onclick" itu kemudian akan memanggil fungsi yang menyebabkannya bergulir.

    Jika Anda melakukannya seperti itu, Anda dapat menggunakan lebih dari satu tombol, asalkan tombolnya terlihat seperti ini:

    <button onclick="scrollTo(document.body, 0, 1250)">To the top</button>
    pengguna4251442
    sumber
    3
    Ini tidak bernyawa.
    dmackerman