react简介
react是有facebook开发出来用于构建前端界面的js组件库,由于其背后的强大背景,使得这款库在技术开发上完全没有问题。
react的优势
前言
大家都可能会遇到这样的问题,那就是滚动事件 。比较获取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='' }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。
如对本文有疑问, 点击进行留言回复!!
同事牛逼啊,写了个隐藏 bug,我排查了 3 天才解决问题!
【JavaScript笔记(一)】万丈高楼平地起 - 基本概念篇
轻松解决 org.apache.taglibs.standard.tlv.JstlCoreTLV 困惑
网友评论