vue项目设置scrollTop不起作用(总结)


Posted in Javascript onDecember 21, 2018

今天在开发中,遇到这样一个情景。一个页面中有三个模块,每个模块对应一个标题,每个模块内容都很长,所以需要点击当前模块对应的标题滚动到模块所在位置。

我想的方案是获取到每个模块距离文档顶部的距离,然后将值赋给对应要滚动的元素。 步骤如下:

首先给每个模块一个id,例如:

<div class="module module1" id="anchor-0">
<div class="module module1" id="anchor-1">
<div class="module module1" id="anchor-2">

点击每个标题的时候获取到当前模块的id

<a v-for="(navItem,index) in navData" :key="index" class="navItem" :class="{active:index == i }" @click="goAnchor('#anchor-'+index)">{{navItem.name}}</a>

methods: {
   // tab点击滚动
   goAnchor(val) {
    let anchor = this.$el.querySelector(val);
 }

*最后就可以获取每个模块距离文档顶部的距离了,然后赋值给对应要滚动的元素就可以了

methods: {
   // tab滚动
   goAnchor(val) {
    let anchor = this.$el.querySelector(val);
    this.$nextTick(() => {
     document.querySelector(".el-main").scrollTop = anchor.offsetTop;
    });
   },

切记:在这里一定要加上this.$nextTick()方法,否则document.querySelector(“.el-main”).scrollTop的值永远为0,不会赋值成功的!

container.scrollTop 一直为0不能赋值的解决方法

watch: {
  historyList () {
   this.$nextTick(() => {
    const container = this.$el.querySelector('.scrolldivmain')
    console.log(container.scrollHeight)
    console.log(container.scrollTop)
    this.$refs.scrolldiv.scrollTo(0, container.scrollHeight + 'px')
    container.scrollTop = container.scrollHeight
    container.scrollTop(0, container.scrollHeight)
    console.log(container.scrollTop) // container.scrollTop 一直为0
   })
  }
 }

注意点

确定下滚动条是在哪里显示的

有个方法判断下:

window.addEventListener('scroll', () => {
    var scrollTop = this.$el.querySelector('.scrolldivmain')
    // console.log(scrollTop.scrollHeight)
    console.log(scrollTop.scrollTop) // 查看打印的值是否有变化 如果有 则说明滚滚动条在这个标签中
    // scrollTop.scrollTop = scrollTop.scrollHeight // 可以尝试下 滚动滚动条。一直在底部则可以设置成功
  }, true)

解决方案

需要用到的地方 调用this.scrollToBottom()即可

<!--element-ui-->

<el-main class="scrolldivmain">
  some code
</el-main>
methods: {
 // 滚动到底部
  scrollToBottom () {
   this.$nextTick(() => {
    setTimeout(() => {
     var scrollTop = this.$el.querySelector('.scrolldivmain')
     scrollTop.scrollTop = scrollTop.scrollHeight
    }, 13)
   })
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript下阻止表单重复提交、防刷新、防后退
Aug 17 Javascript
7款风格新颖的jQuery/CSS3菜单导航分享
Apr 23 Javascript
判断window.onload是否多次使用的方法
Sep 21 Javascript
JS实现为表格动态添加标题的方法
Mar 31 Javascript
js实现Form栏显示全格式时间时钟效果代码
Aug 19 Javascript
JavaScript如何禁止Backspace键
Dec 02 Javascript
js与jQuery实现checkbox复选框全选/全不选的方法
Jan 05 Javascript
微信小程序之事件交互操作实例分析
Dec 03 Javascript
express 项目分层实践详解
Dec 10 Javascript
layui 对弹窗 form表单赋值的实现方法
Sep 04 Javascript
Vue动态加载图片在跨域时无法显示的问题及解决方法
Mar 10 Javascript
探索浏览器页面关闭window.close()的使用详解
Aug 21 Javascript
浅谈Vue服务端渲染框架Nuxt的那些事
Dec 21 #Javascript
JS二级菜单不同实现方法分析【4种方法】
Dec 21 #Javascript
vue中eslintrc.js配置最详细介绍
Dec 21 #Javascript
angularjs http与后台交互的实现示例
Dec 21 #Javascript
JS执行控制之节流模式实例分析
Dec 21 #Javascript
vue favicon设置以及动态修改favicon的方法
Dec 21 #Javascript
微信小程序自定义键盘 内部虚拟支付
Dec 20 #Javascript
You might like
咖啡风味 世界咖啡主要分布分布 咖啡的生长要求
2021/03/06 新手入门
七款最流行的PHP本地服务器分享
2013/02/19 PHP
PHP中使用json数据格式定义字面量对象的方法
2014/08/20 PHP
php通过排列组合实现1到9数字相加都等于20的方法
2015/08/03 PHP
jquery JSON的解析方式
2009/07/25 Javascript
js运动框架_包括图片的淡入淡出效果
2013/05/11 Javascript
用Js实现的动态增加表格示例自己写的
2013/10/21 Javascript
浅谈JavaScript的内置对象和浏览器对象
2016/06/03 Javascript
微信小程序教程之本地图片上传(leancloud)实例详解
2016/11/16 Javascript
JS使用正则实现去掉字符串左右空格的方法
2016/12/27 Javascript
详解百度百科目录导航树小插件
2017/01/08 Javascript
jQuery控制元素隐藏和显示
2017/03/03 Javascript
BootStrap表单宽度设置方法
2017/03/10 Javascript
从零开始学习Node.js系列教程一:http get和post用法分析
2017/04/13 Javascript
vue 插值 v-once,v-text, v-html详解
2018/01/19 Javascript
基于vue开发的在线付费课程应用过程
2018/01/25 Javascript
Vue表单控件绑定图文详解
2019/02/11 Javascript
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
Vue2.x-使用防抖以及节流的示例
2021/03/02 Vue.js
[05:02]2014DOTA2 TI中国区预选赛精彩TOPPLAY第三弹
2014/06/25 DOTA
python实现的登录和操作开心网脚本分享
2014/07/09 Python
python中的插值 scipy-interp的实现代码
2018/07/23 Python
python中将zip压缩包转为gz.tar的方法
2018/10/18 Python
python调用java的jar包方法
2018/12/15 Python
python通过配置文件共享全局变量的实例
2019/01/11 Python
PyTorch中常用的激活函数的方法示例
2019/08/20 Python
关于pymysql模块的使用以及代码详解
2019/09/01 Python
Python实现查找数据库最接近的数据
2020/06/08 Python
Python实现一个简单的递归下降分析器
2020/08/01 Python
移动端rem布局的两种实现方法
2018/01/03 HTML / CSS
巴西化妆品商店:Lojas Rede
2019/07/26 全球购物
.NET面试10题
2014/02/24 面试题
开办化妆品公司创业计划书
2013/12/26 职场文书
不服从上级领导安排的检讨书
2014/09/14 职场文书
班级光棍节联谊会策划书
2014/10/10 职场文书
服务员态度差检讨书
2014/10/28 职场文书