您好,欢迎访问一九零五行业门户网

实现tab吸顶使用react.js中的问题

在react项目开发中有一个需求是,页面滚动到tab所在位置时,tab要固定在顶部。
实现的思路其实很简单,就是判断当滚动距离scrolltop大于tab距离页面顶部距离offsettop时,将tab的position变为fixed。
在react中,我在state中设置一个navtop属性,切换这个属性的值为true或者false,然后tab标签使用classnames()这个方法来利用navtop的值添加类名fixed。
一开始我是这样写的:
import cs from 'classnames'; class fixedtab extends react.component{ constructor(props){ super(props); this.state = { navtop: false } this.$tab = null; this.offsettop = 0; } componentdidmount(){ this.$tab = this.refs.tab; if(this.$tab){ this.offsettop = this.$tab.offsettop; window.addeventlistener('scroll',this.handlescroll); } } handlescroll(){ let stop = document.documentelement.scrolltop || window.pageyoffset || document.body.scrolltop; if(stop >= this.offsettop){ this.setstate({ navtop: true }) } if(stop < this.offsettop){ this.setstate({ navtop:false }) } } render(){ return( <p ref="tab" classname={cs({'fixed':this.state.navtop})}></p> ) } }
然后我发现这样写有问题,当我滚动条滚动距离达到条件时,tab是出现了吸顶的效果,但一瞬间又恢复了,滚动条也回弹了,一直无法继续下拉。
我一开始以为判断逻辑有问题,但一直找不到解决的办法,后来我怀疑是state值改变的时间差导致的,好像陷入了一个死循环,然后我就在判断滚动距离之前加了一个判断navtop的状态。
修改的主要代码如下:
handlescroll(){ let stop = document.documentelement.scrolltop || window.pageyoffset || document.body.scrolltop; if(!this.state.navtop && stop >= this.offsettop){ this.setstate({ navtop: true }) } if(stop < this.offsettop){ this.setstate({ navtop:false }) } }
这样修改之后吸顶效果就正常了。
以上就是实现tab吸顶使用react.js中的问题 的详细内容。
其它类似信息

推荐信息