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

React简介

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

React的优势

解决大规模项目开发中数据不断变化变得难以操作的问题;

组件化开发,使得开发更加快速;

单向数据流,有利于找到问题;

虚拟DOM,在React内部有一套diff算法可以快速的计算出整体需要改动的位置,从而做到快速局部刷新;举个栗子:删除一个列表再插入个新表,计算后会比较出不同然后插进去;

前言

上海领思教育科技有限公司是一家致力于高素质软件开发人才培养的公司,一方面解决企业招不到优秀人才 的困扰,同时为优秀的大学毕业生提供改变命运的机遇。公司自成立以来,一直坚持采用“好老师+好学生+ 好学习气氛”的培养模式,已经培养了一批又一批的IT人才。

上海领思期待您的加盟。

地址:上海市浦东新区临港新城水芸路300号501室

电话:021-58010107

网址:http://www.lingsiedu.cn

简历投递:hr@lingsiedu.cn

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

要想实现滚动,那就必须得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=''

}

总结

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 学习资料 react官方首页https://facebook.github.io/react/react中文htt...
    耳_总阅读 388评论 0 0
  • web开发早期 在web开发的早期时代(据史书记载,那段不堪回首的岁月被称之为web1.0时代 (╯▽╰)),开发...
    桂圆_noble阅读 874评论 3 4
  • React简介 一、什么是React 废话不说,我们先看看官方是杂说的 React is a JavaScript...
    TigerChain阅读 2,064评论 0 11
  • React简介 React是什么? React是Facebook开源的一个用于构建用户界面的Javascript库...
    birdshome阅读 473评论 0 0
  • 定位堪称是全球最著名的营销策略,他改变了人类“满足需求”的旧有营销认识,开创了“胜出竞争”的营销之道。《定位》作者...
    elleyfonia阅读 449评论 0 0