Я взломал ваш html / javascript на одной странице. Короче говоря - используйте плагин https://github.com/mathiasbynens/jquery-smooth-scrolling/blob/master/jquery.smoothscroll.js (вот откуда javascript)
Хотя люди говорят, что используют «плавную прокрутку» https://www.w3schools.com/cssref/pr_scroll-behavior.asp Но я не смог заставить это работать
Тем не менее, похоже, что это конечная строка
$scrollElement.stop().animate({ 'scrollTop': $hash.offset().top }, speed, function() {
location.hash = hash;
});
Так что, как правило, после завершения анимации обновите ссылку.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Smooth scroll</title>
<style>
#sneaker {
margin-top: 1500px;
width: 100%;
}
</style>
</head>
<body>
<div id="main-container">
<a class="page-scroll" href="#sneaker">Take you to the sneaker</a>
<img id="sneaker" src="adidas-superstar-2-white-black.jpg" alt="adidas superstar sneaker">
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.js"></script>
<script >
/*! http://mths.be/smoothscroll v1.5.2 by @mathias */
;(function(document, $) {
var $scrollElement = (function() {
// Find out what to scroll (html or body)
var $html = $(document.documentElement),
$body = $(document.body),
bodyScrollTop;
if ($html.scrollTop()) {
return $html;
} else {
bodyScrollTop = $body.scrollTop();
// If scrolling the body doesn’t do anything
if ($body.scrollTop(bodyScrollTop + 1).scrollTop() == bodyScrollTop) {
return $html;
} else {
// We actually scrolled, so undo it
return $body.scrollTop(bodyScrollTop);
}
}
}());
$.fn.smoothScroll = function(speed) {
speed = ~~speed || 400;
// Look for links to anchors (on any page)
return this.find('a[href*="#"]').click(function(event) {
var hash = this.hash,
$hash = $(hash); // The in-document element the link points to
// If it’s a link to an anchor in the same document
if (location.pathname.replace(/^\//, '') === this.pathname.replace(/^\//, '') && location.hostname === this.hostname) {
// If the anchor actually exists…
if ($hash.length) {
// …don’t jump to the link right away…
event.preventDefault();
// …and smoothly scroll to it
$scrollElement.stop().animate({ 'scrollTop': $hash.offset().top }, speed, function() {
location.hash = hash;
});
}
}
}).end();
};
}(document, jQuery));
</script>
<script>
$('html').smoothScroll();
</script>
</body>
</html>