Because you are using router in hash mode, you will not be able to scroll that easily because scrolling to /#something
will actually redirect you to ‘something’ page.
You will have to emulate scrolling behaviour on your own, try doing something like that:
//P.S. the code is written for Vue 2.
//You will have to adjust it to Vue 1.
//Your view:
<a class="porto-button" @click="scrollMeTo('porto')">Porto, Portugal</a>
...
<div ref="porto" class="fl-porto">
//Your code:
methods: {
scrollMeTo(refName) {
var element = this.$refs[refName];
var top = element.offsetTop;
window.scrollTo(0, top);
}
}
How it works:
- Set the references through
ref
attribute to the element you would like to scroll to; - Write a function that will programmatically set
window.scrollY
to thetop
of the referenced element. - Job is done 🙂
Update 1:
jsfiddle https://jsfiddle.net/5k4ptmqg/4/
Update 2:
Seems that in Vue 1 ref="name"
looked like el:name
(docs), here is an updated example:
https://jsfiddle.net/5y3pkoyz/2/