您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

关于React.Js添加与删除onScroll事件详解

2024/3/3 14:05:12发布19次查看
react是有facebook开发出来用于构建前端界面的js组件库,由于其背后的强大背景,使得这款库在技术开发上完全没有问题。本文主要给大家介绍了关于react.js添加与删除onscroll事件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
react的优势
解决大规模项目开发中数据不断变化变得难以操作的问题;
组件化开发,使得开发更加快速;
单向数据流,有利于找到问题;
虚拟dom,在react内部有一套diff算法可以快速的计算出整体需要改动的位置,从而做到快速局部刷新;举个栗子:删除一个列表再插入个新表,计算后会比较出不同然后插进去;
前言
大家都可能会遇到这样的问题,那就是滚动事件 。比较获取p的滚动事件,在reactjs想要给p添加一个滚动事件,那基本上是添加不上的(可能是我的能力有限吧,反正我到目前为止,还没有找到可以直接给p添加滚动事件的)。
要想实现滚动,那就必须得componentwillmount里注册scroll事件, window.addeventlistener(‘scroll', this.onscroll.bind(this)) ,添加事件非常容易的就添加上了。
在componentwillunmount 里删除 window.removeeventlistener(‘scroll', this.onscroll.bind(this))  。
添加容易,删除难,上面那种 remove是删除不了的。在其它页面里,如果你滚动也会触发 onscroll里的事件,此时就会报错,说组件已经卸载,不能进行操作,检查一下代码等等吧。
我想肯定有遇到了,也有解决的办法,果真找到了一篇文章移除 scroll 办法的。
代码如下:
componentdidmount() {  regscroll(this.handler.bind(this));  //window.addeventlistener('scroll', this.handler.bind(this),false) } componentwillunmount() {  window.onscroll = '';  //window.removeeventlistener('scroll', this.handler.bind(this),false) }  //添加事件监听 function regscroll(myhandler) {  if (window.onscroll === null) {  window.onscroll = myhandler  } else if (typeof window.onscroll === 'function') {  var oldhandler = window.onscroll;  window.onscroll = function () {  myhandler();  oldhandler();  }  } } //删除所有事件监听 function removescrollhandler(){  window.onscroll='' }
相关推荐:
html5中在元素滚动条在滚动时触发的事件onscroll
javascript触发onscroll事件的函数节流详解
关于onscroll事件在ie6下每次滚动触发三次bug说明_javascript技巧
以上就是关于react.js添加与删除onscroll事件详解的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product