前端Vue专辑VueVue.js

vue 实现跨页面锚点

2018-11-02  本文已影响15人  东京的雨不会淋湿首尔

1.先记录一下非跨页面的实现方法:
官方文档有写,这样在一个组件里改变hash,比如#anchor-1,
就能够跳到id为anchor-1的位置

  router.js中添加

          mode: 'history',
              srcollBehavior(to,from,savedPosition){
              if(to.hash){
                  return {
                  selector:to.hash
                 }
          }}

2.但是如果我们要做页面跳转时的锚点,
比如 a组件点击 pageb#anchor-1跳转到b组件,b组件需要根据hash跳转到指定位置,就不能用上面的方法了。
可以如下实现:
在b组件内添加一个方法:

goAnchor(selector) {
                let anchor = this.$el.querySelector(selector)
                document.documentElement.scrollTop = anchor.offsetTop 
            },
#这里是根据root 节点来scroll,可以自己根据需要调整scroll对象

在b组件的mounted中添加

this.$nextTick(()=>[
                    this.goAnchor(window.location.hash)
                ])

这样跳转到静态页面是没有问题了

但是如果

b组建执行锚点的地方是通过ajax获取数据,v-for渲染的,这样在goAnchor方法中是获取不到anchor节点的,需要等待渲染完成。我们可以通过watch来观察数据是否加载完毕

data() {
            return {
                        items:[]  #通过ajax获取
            }
},
watch:{
            items:function () {
                this.$nextTick(()=>[
                    this.goAnchor(window.location.hash)
                ])
            }
        },

这样就能解决跨页面的锚点问题

上一篇 下一篇

猜你喜欢

热点阅读