我是靠谱客的博主 结实纸飞机,这篇文章主要介绍html5中在元素滚动条在滚动时触发的事件onscroll,现在分享给大家,希望可以做个参考。

实例

<div> 元素滚动时执行 JavaScript

复制代码
1
<div onscroll="myFunction()">
登录后复制

定义和用法

onscroll 事件在元素滚动条在滚动时触发。

提示: 使用 CSS overflow 样式属性来创建元素的滚动条。

浏览器支持

@R8~926B%ZJ[G{{BH9A(`CS.png

语法

HTML 中:

复制代码
1
<element onscroll="myScript">
登录后复制

JavaScript 中:

复制代码
1
object.onscroll=function(){myScript};
登录后复制

JavaScript 中, 使用 addEventListener() 方法:

复制代码
1
object.addEventListener("scroll", myScript);
登录后复制

注意: Internet Explorer 8 及更早 IE 版本不支持 addEventListener() 方法。

Technical Details

技术细节

是否支持冒泡:Yes
是否可以取消:NO
事件类型:Event
支持的 HTML 标签:<address>, <blockquote>, <body>, <caption>, <center>, <dd>, <dir>, <div>, <dl>, <dt>, <fieldset>, <form>, <h1> - <h6>, <html>, <li>, <menu>, <object>, <ol>, <p>, <pre>, <select>, <tbody>, <textarea>, <tfoot>, <thead>, <ul>

onscroll事件失效

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<!DOCTYPE html> <html> <head>   <meta charset="utf-8"> </head> <body onscroll="checkscroll()">   <div class="father" >     <div class="son">我是移动块</div>   </div> </body> </html> <style type="text/css"> html, body {   width: 100%;   height: 100%;   /*overflow-x:hidden;*/   /*overflow: scroll;*/ } .father {   width: 100%;   height: 100%;   box-sizing: border-box; } .son {     height: 3000px;   background-color: yellow;   width: 100%;   font-size: 80px;   display: flex;   justify-content: center;   align-items: center; } </style> <script type="text/javascript">   function checkscroll() {       console.info(window.scrollY)   } </script>
登录后复制

大家可以将这段代码copy亲自测试一下,在有和没有overflow属性之间切换,就明白了。

因为很多同学在开发项目时,会有脚手架之类的文件进行快速开发,但是有的脚手架会在入口的html文件,设置overflow: scroll/auto。

这个属性在入口级别的文件中最好不要随意使用,造成的scroll滑动监听整体失效,你无论如何也不会想到是这个原因。

打个比方:

APP.vue

Q`R~5N{@9AO8(1EE76OKCCW.png

这是用vue.js写的页面,我在其中用了vux(一个基于vuejs的移动组件库)的一个组件view-box,当时我找遍了所有的文件,并没有那里

有over-flow 样式;但是scroll事件失效,window.scrollY一直为0, 最后我发现所有页面都是如此,于是我就定位在入口的几个文件,将

相关的引入组件也进行排查,终于在view-box,这个组建里找到了over-flow:auto;样式。注释掉后,就正常了

所以说:over-flow:auto;如果放在入口文件并且放在包裹的父元素上,一定要慎重!

以上就是html5中在元素滚动条在滚动时触发的事件onscroll的详细内容,更多请关注靠谱客其它相关文章!

最后

以上就是结实纸飞机最近收集整理的关于html5中在元素滚动条在滚动时触发的事件onscroll的全部内容,更多相关html5中在元素滚动条在滚动时触发内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(265)

评论列表共有 0 条评论

立即
投稿
返回
顶部