在web页面中onscroll事件不触发的状况记录

起因

今日在用vue开发前端页面的时候,需要添加一个无限加载的效果。这时候就用到了onscroll事件,拿出来以前开发的无限加载的vue组件来使用,发现并没有实现预期的效果。然后进行排查,发现是一直不触发onscroll事件。

既然找到了问题的所在,就要找到解决的办法,排查了好久,发现是因为css样式导致的scroll事件不触发。

onscroll不触发的原因和解决

这种scroll事件不触发的原因是因为下面这样一段css代码:

html,body{overflow:auto;height:100%;}

这行代码一般会出现在reset的css重置文件中,而它就是导致onscroll事件不触发的元凶。

我们只要把这行代码去掉或者稍作修改就能解决问题。

细看上面的代码,其实两句css代码是冲突的,html,body设置height:100%,那么我们就是希望单屏页面的效果,然后又添加overflow:auto或者overflow:scroll就是说页面可以滚动,那么既然页面可以滚动,那还要height:100%有什么作用。

并且出现onscroll事件不触发的情况是html和body同时设置{overflow:auto;height:100%}导致的。

 

本文内容很简单,但是对于遇到此类问题的开发人员来说是很用的。

http://webfront-js.com/articaldetail/156.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值