vue实现锚点跳转scrollIntoView()使用案例

 更新时间:2023年07月12日 11:29:57   作者:遥远的救世主○  
这篇文章主要介绍了vue实现锚点跳转scrollIntoView()使用案例,文中结合实例代码介绍了vue锚点跳转的三种方式(页内跳转,跨页跳转,函数跳转),需要的朋友可以参考下

vue实现锚点跳转:scrollIntoView()

说明:

滚动到某个特定元素 :scrollIntoView();例如form表单或者div滚动到底部,

document.getElementsByClassName(‘’)或者document.getElementsById(‘’)

获取到元素后即可实现回到可视化区域(也可理解为回到顶部)。

使用案例:

<div> v-for="(value,index) in data" class="roll">{{...}}</div>  

js部分

methods:{
  scrollToPosition(index){
     document.getElementsByClassName('roll')[index].scrollIntoView()
}

这样就利用scrollIntoView()简单实现了一个锚点跳转,下边讲解scrollIntoView中的一些属性:

scrollIntoView(true)相等于scrollIntoView();元素的顶端将和其所在滚动区的可视区域的顶端对齐为true时相应的 scrollIntoViewOptions: {block: “start”, inline:“nearest”}。这是这个参数的默认值。

scrollIntoView(false)元素的底端将和其所在滚动区的可视区域的底端对齐为false时相应的scrollIntoViewOptions: {block: “end”, inline: “nearest”}。

同时他的参数也可以配置成一个object对象

  scrollIntoView({
  behavior:auto //定义动画过渡效果"auto"或 "smooth" 之一。默认为 "auto"。
  block:start//定义垂直方向的对齐, "start", "center", "end", 或 "nearest"之一。默认为 "start"。
  inline:nearest//"start", "center", "end", 或 "nearest"之一。默认为 "nearest"。
  })

其中smooth是平滑滚动 start和end是目标滚动到的位置

注意:兼容性的问题多数主流浏览器已经支持其基本功能,也就是说,使用true,false两个参数,来实现木讷的定位(没有滚动动画)是没有任何问题的,但是传入object参数时,IE各种版本会直接忽略,全部看成true参数属性,如果想看到滚动动画,使用火狐和chrome。

vue锚点跳转的三种方式(页内跳转,跨页跳转,函数跳转)

1.需求

最近遇到一个需求,需要从一个页面跳到另一个页面的指定锚点,如果是页面上的锚点还简单,但是那个锚点在页面的组件里面。所以稍微研究了一下

2.跳转锚点的基本方式

2.1 页面内通过点击来跳转

即添加一个a标签,href以#开头,然后在需要跳转的地方添加一个element,id设置为a标签href属性相同的值,只是不要#,就可以了,这是最简单的方式

<a href="#miao">去找喵星人</a>
<h3 id="miao">喵星人基地</h3>

2.2 从A页面跳转到B页面的指定锚点(锚点就在页面上,不在子组件中)

我用的vue,所以在vue路由跳转时只要在path后面加上#锚点就可以了,比如我要跳到B页面id为miao的锚点,那么path=xxxx?#miao,当遇到query参数的情况,将#miao放到url的最后就行了,其他的也一样,反正只要把锚点放在url最后就行了,然后进行跳转即可

 this.$router.push({
            path: `/detail?#miao`,
            query: {
              comment: `${commentId}`
            }
          })

注意:因为默认的vue单页使用的是hash模式,以#作为路由分割标识符,就会导致有歧义而无法正常达到需求,如果你又不想使用history模式,那么就使用2.3的方式,使用代码进行锚点跳转

2.3 直接使用代码进行锚点跳转

有的情况,只能使用代码进行锚点跳转,比如从一个页面跳到另一页面子组件内的指定锚点,这与2.2还是有区别的,我已经试过,如果锚点在子组件内,不在当前路由页面中,那么2.2的方式并不会起作用。解决方法:
将锚点作为query属性,或者其他的方式,将锚点的值传给B页面,然后B页面再通过props的方式传给他的子组件,最后在子组件中使用代码进行锚点跳转

// 这是传到组件中的数据
 props: {
      commentId: String
  }
  mounted () {
  // 判断commentId 是否有值,如果没有的话,就不进行跳转,我这里就用'null'来判断了,你们随意
  // document.querySelector用来获取element,有个坑,id值不能全为数字,否则报错,所以我在id值前面加了id,id格式大致是:id123456
  // scrollIntoView就是用来跳转到锚点的函数
        if (this.commentId !== 'null') {
          let inter = setInterval(() => {
            let target = document.querySelector(`#id${this.commentId}`)
            if (target) {
              clearInterval(time)
              target.scrollIntoView()
            }
          },100)
        }
    },

到此这篇关于vue实现锚点跳转 scrollIntoView()的文章就介绍到这了,更多相关vue锚点跳转 scrollIntoView()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue2中插槽(slot)的基本使用规范

    vue2中插槽(slot)的基本使用规范

    插槽(Slot)是Vue提出来的一个概念,正如名字一样,插槽用于决定将所携带的内容,插入到指定的某个位置,从而使模板分块,具有模块化的特质和更大的重用性,下面这篇文章主要给大家介绍了关于vue2中插槽(slot)的基本使用规范的相关资料,需要的朋友可以参考下
    2022-03-03
  • 完美解决vue 项目开发越久 node_modules包越大的问题

    完美解决vue 项目开发越久 node_modules包越大的问题

    这篇文章主要介绍了vue 项目开发越久 node_modules包越大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • Vue中计算属性和监听属性及数据的响应式更新和依赖收集基本原理讲解

    Vue中计算属性和监听属性及数据的响应式更新和依赖收集基本原理讲解

    computed是vue的配置选项,它的值是一个对象,其中可定义多个计算属性,每个计算属性就是一个函数,下面这篇文章主要给大家介绍了关于vue中计算属性computed的详细讲解,需要的朋友可以参考下
    2023-03-03
  • vue 组件中添加样式不生效的解决方法

    vue 组件中添加样式不生效的解决方法

    这篇文章主要介绍了vue 组件中添加样式不生效的解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • vue小白入门教程

    vue小白入门教程

    vue是一套用于构建用户界面的渐进式框架,本文通过实例给大家介绍了vue入门教程适用小白初学者,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2018-04-04
  • Vue列表页渲染优化详解

    Vue列表页渲染优化详解

    这篇文章主要为大家详细介绍了Vue列表页渲染优化的操作,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • vue background-image 不显示问题的解决

    vue background-image 不显示问题的解决

    这篇文章主要介绍了vue background-image 不显示问题的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Vue中父组件向子组件通信的方法

    Vue中父组件向子组件通信的方法

    可以使用props将父组件的数据传给子组件。子组件在接受数据时要显示声明props。下面通过一个例子给大家介绍Vue中父组件向子组件通信的方法,需要的朋友参考下吧
    2017-07-07
  • 如何用vue-pdf包实现pdf文件预览,支持分页

    如何用vue-pdf包实现pdf文件预览,支持分页

    这篇文章主要介绍了如何用vue-pdf包实现pdf文件预览,支持分页问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • 在vue中axios设置timeout超时的操作

    在vue中axios设置timeout超时的操作

    这篇文章主要介绍了在vue中axios设置timeout超时的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09

最新评论