I am a JavaScript rookie. Using a free template code for building a web page. I have a perfectly working back to top snippet but the problem is, it is adding "#" to the URL when i click on it. And when i click browser back button i had to click twice as it is removing the hash on first click and then click again to go to previous page, which is pretty annoying. Though there are tons of jQuery examples to achieve this i don't want to add jQuery and use just the JavaScript i have. Here is the code. Is there any way to remove "#" from the URL when i click the scroll to top anchor?. I tried changing the anchor tag to button as well but i could not manage to get it work. Pleas help.
HTML
<a href="#" class="back-to-top"><i class="bi bi-arrow-up-short"></i></a>
JS
(function () {
/**
* Easy selector helper function
*/
const select = (el, all = false) => {
el = el.trim()
if (all) {
return [...document.querySelectorAll(el)]
} else {
return document.querySelector(el)
}
}
/**
* Easy event listener function
*/
const on = (type, el, listener, all = false) => {
let selectEl = select(el, all)
if (selectEl) {
if (all) {
selectEl.forEach(e => e.addEventListener(type, listener))
} else {
selectEl.addEventListener(type, listener)
}
}
}
/**
* Easy on scroll event listener
*/
const onscroll = (el, listener) => {
el.addEventListener('scroll', listener)
}
/**
* Back to top button
*/
let backtotop = select('.back-to-top')
if (backtotop) {
const toggleBacktotop = () => {
if (window.scrollY > 100) {
backtotop.classList.add('active')
} else {
backtotop.classList.remove('active')
}
}
window.addEventListener('load', toggleBacktotop)
onscroll(document, toggleBacktotop)
}
})();
CodePudding user response:
To prevent the #
being added to the url you can use preventDefault
to prevent the default anchor link behaviour:
document.querySelector('a').addEventListener('click', (event) => {
event.preventDefault();
window.scrollTo(0, 0);
});
.spacer {
width: 100%;
height: 150vh;
border: 1px dashed black;
}
<div class="spacer"></div>
<a href="#">Back to Top</a>
<iframe name="sif1" sandbox="allow-forms allow-modals allow-scripts" frameborder="0"></iframe>
or use window.scroll
for native smooth scrolling behaviour (but be wary of the browser support)
document.querySelector('a').addEventListener('click', (event) => {
event.preventDefault();
window.scroll({
top: 0,
behavior: 'smooth'
});
});
.spacer {
width: 100%;
height: 150vh;
border: 1px dashed black;
}
<div class="spacer"></div>
<a href="#">Back to Top</a>
<iframe name="sif2" sandbox="allow-forms allow-modals allow-scripts" frameborder="0"></iframe>
CodePudding user response:
does it answer to you question ?
make a on click function with this sample:
window.scrollTo(0, 0);
<iframe name="sif3" sandbox="allow-forms allow-modals allow-scripts" frameborder="0"></iframe>
CodePudding user response:
You can use JavaScript to scroll to the top:
backtotop.addEventListener("click", () => {
window.scrollTo({top: 0});
return false;
});
CodePudding user response:
Maybe you just want to prevent the default behavior.
document.querySelector(".back-to-top").addEventListener("click", (e) => {
e.preventDefault();
})
CodePudding user response:
Use javascript:void(0) instead of #
It will work.