React.Js添加與刪除onScroll事件的方法詳解
React簡介
React是有Facebook開發(fā)出來用于構建前端界面的JS組件庫,由于其背后的強大背景,使得這款庫在技術開發(fā)上完全沒有問題。
React的優(yōu)勢
- 解決大規(guī)模項目開發(fā)中數據不斷變化變得難以操作的問題;
- 組件化開發(fā),使得開發(fā)更加快速;
- 單向數據流,有利于找到問題;
- 虛擬DOM,在React內部有一套diff算法可以快速的計算出整體需要改動的位置,從而做到快速局部刷新;舉個栗子:刪除一個列表再插入個新表,計算后會比較出不同然后插進去;
前言
大家都可能會遇到這樣的問題,那就是滾動事件 。比較獲取div的滾動事件,在ReactJS想要給div添加一個滾動事件,那基本上是添加不上的(可能是我的能力有限吧,反正我到目前為止,還沒有找到可以直接給DIV添加滾動事件的)。
要想實現滾動,那就必須得componentWillMount里注冊scroll事件, window.addEventListener(‘scroll', this.onScroll.bind(this)) ,添加事件非常容易的就添加上了。
在componentWillUnmount 里刪除 window.removeEventListener(‘scroll', this.onScroll.bind(this)) 。
添加容易,刪除難,上面那種 remove是刪除不了的。在其它頁面里,如果你滾動也會觸發(fā) 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)
}
//添加事件監(jiān)聽
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();
}
}
}
//刪除所有事件監(jiān)聽
function removeScrollHandler(){
window.onscroll=''
}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
React如何解決fetch跨域請求時session失效問題
這篇文章主要給大家介紹了關于React如何解決fetch跨域請求時session失效問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-11-11
詳解在React.js中使用PureComponent的重要性和使用方式
這篇文章主要介紹了詳解在React.js中使用PureComponent的重要性和使用方式,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07
基于React Context實現一個簡單的狀態(tài)管理的示例代碼
本文主要介紹了基于React Context實現一個簡單的狀態(tài)管理的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-07-07
React實現createElement 和 cloneElement的區(qū)別
本文詳細介紹了React中React.createElement和React.cloneElement兩種方法的定義、用法、區(qū)別及適用場景,具有一定的參考價值,感興趣的可以了解一下2024-09-09

