React.Js添加与删除onScroll事件的方法详解

前端之家收集整理的这篇文章主要介绍了React.Js添加与删除onScroll事件的方法详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_3010@

React简介


@H
3010@React是有Facebook开发出来用于构建前端界面的JS组件库,由于其背后的强大背景,使得这款库在技术开发上完全没有问题。


@H
301_0@

React的优势

  • 解决大规模项目开发中数据不断变化变得难以操作的问题;
  • 组件化开发,使得开发更加快速
  • 单向数据流,有利于找到问题;
  • 虚拟DOM,在React内部有一套diff算法可以快速的计算出整体需要改动的位置,从而做到快速局部刷新;举个栗子:删除一个列表再插入个新表,计算后会比较出不同然后插进去;
@H_301_0@

前言

@H_301_0@大家都可能会遇到这样的问题,那就是滚动事件 。比较获取div的滚动事件,在ReactJS想要给div添加一个滚动事件,那基本上是添加不上的(可能是我的能力有限吧,反正我到目前为止,还没有找到可以直接给DIV添加滚动事件的)。

@H_301_0@要想实现滚动,那就必须得componentWillMount里注册scroll事件, window.addEventListener(‘scroll',this.onScroll.bind(this)) 添加事件非常容易的就添加上了。

@H_301_0@在componentWillUnmount 里删除 window.removeEventListener(‘scroll',this.onScroll.bind(this))

@H_301_0@添加容易,删除难,上面那种 remove是删除不了的。在其它页面里,如果你滚动也会触发 onScroll里的事件,此时就会报错,说组件已经卸载,不能进行操作,检查一下代码等等吧。

@H_301_0@我想肯定有遇到了,也有解决的办法,果真找到了一篇文章移除 scroll 办法的。

@H_301_0@

代码如下:

componentWillUnmount() {
window.onscroll = '';
//window.removeEventListener('scroll',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=''
}

@H_301_0@

总结

@H_301_0@以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持

原文链接:https://www.f2er.com/js/35392.html

猜你在找的JavaScript相关文章