scrollTop设置后一直为0的解决方案(最全)
2021/8/21 6:06:33
本文主要是介绍scrollTop设置后一直为0的解决方案(最全),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
近期在业务中要实现keep-alive记住滚动条位置,发现scrollTop一直为0,排除各个组件的问题后仍未找到解决办法,最后考虑到是css的问题。
mounted() { //一开始使用的@scroll绑定在container上没有触发,后来发现使用这种方法有效 window.addEventListener('scroll', this.scroll, true) }, methods: { //封装的兼容性方法 scroll() { //获得页面向左、向上卷动的距离 function getScroll() { return { left: window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0, top: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0 }; } //这里的this.$nextTick一定要有 this.$nextTick(() => { //这里是外层container const container = this.$el.querySelector('.container') if (container) { //正常获取scrollTop console.log(this.$el.querySelector('.container').scrollTop); } }) } }
.container { /* 这两个是必须要有的,不要写成overflow-y:auto; */ overflow-y: scroll; height: 100%; }
如有不足欢迎指正
这篇关于scrollTop设置后一直为0的解决方案(最全)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15在使用平台私钥进行解密时提示 "私钥解密失败" 错误信息是什么原因?-icode9专业技术文章分享
- 2024-11-15Layui框架有哪些方式引入?-icode9专业技术文章分享
- 2024-11-15Layui框架中有哪些减少对全局环境的污染方法?-icode9专业技术文章分享
- 2024-11-15laydate怎么关闭自动的日期格式校验功能?-icode9专业技术文章分享
- 2024-11-15laydate怎么取消初始日期校验?-icode9专业技术文章分享
- 2024-11-15SendGrid 的邮件发送时,怎么设置回复邮箱?-icode9专业技术文章分享
- 2024-11-15使用 SendGrid API 发送邮件后获取到唯一的请求 ID?-icode9专业技术文章分享
- 2024-11-15mailgun 发送邮件 tags标签最多有多少个?-icode9专业技术文章分享
- 2024-11-15mailgun 发送邮件 怎么批量发送给多个人?-icode9专业技术文章分享
- 2024-11-15如何搭建web开发环境并实现 web项目在浏览器中访问?-icode9专业技术文章分享