当前位置: 代码网 > it编程>编程语言>Javascript > vue和uniapp页面实现自动滚动到最底部

vue和uniapp页面实现自动滚动到最底部

2024年06月11日 Javascript 我要评论
vue和uniapp页面自动滚动到最底部vue项目中自动滚动到最底部首先可以通过这个方法 获取到当前滚动的元素是哪一个这个方法定义script标签里 export default外面然后滚动的时候可以

vue和uniapp页面自动滚动到最底部

vue项目中自动滚动到最底部

首先可以通过这个方法 获取到当前滚动的元素是哪一个

这个方法定义script标签里 export default外面

然后滚动的时候可以在控制台中打印出当前滚动的什么元素

function findscroller(element) {
    element.onscroll = function() { console.log(element)} 

    array.from(element.children).foreach(findscroller);
}

findscroller(document.body);  

然后找到这个元素 添加ref='list'

这个时候就有两种方法

1.第一种就是给这个元素的scrolltop元素距离页面顶部的距离设置一个超大的值 这样每次输入对话 就会自动滚动到最底部了 但是这个方法不是很建议

2.第二个方法就是给scrolltop设置scrollheight当前页面的高度

this.$nexttick(() => {  // 一定要用nexttick
  this.$refs.list.scrolltop = this.$refs.list.scrollheight
})

uniapp中滚动到最底部

在uniapp中 使用ref会得到undefined 不可以用ref获取dom

推荐使用这个方法

首先给最外面的盒子加一个高度

.wrapper{
       height:auto!important;
   }

然后使用内置的api

 this.$nexttick(()=>{
          uni.pagescrollto({
              scrolltop: 2000000,    //滚动到页面的目标位置(单位px)
              duration: 0    //滚动动画的时长,默认300ms,单位 ms
          });

vue或者uniapp阻止页面滚动

最近uniapp有个需求,页面底部增加悬浮窗,代码上完之后允许上下拖拽,写完之后发现当页面超出屏幕长度的时候拖拽就瞎跑,悬浮窗上下移动页面也跟着移动,思考了下,在滚动触发的时候把当前页面的滚动条锁死,当拖拽离开屏幕的时候再还原,完美解决

话不多说上代码

// 阻止页面滚动

var box=function(e){passive: false ;};
document.body.style.overflow='hidden';
document.addeventlistener("touchmove",box,false);
// 允许页面滚动

var box=function(e){passive: false };
document.body.style.overflow=''; // 出现滚动条
document.removeeventlistener("touchmove",box,false);

完毕,组件引入什么的我就不上代码了,太简单了直接省略

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com