浅谈react.js中实现tab吸顶效果的问题
2017-09-06 07:55
776 查看
在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( <div ref="tab" className={cs({'fixed':this.state.navTop})}></div> ) } }
然后我发现这样写有问题,当我滚动条滚动距离达到条件时,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 }) } }
这样修改之后吸顶效果就正常了。
我认为就是setState方法导致的问题,setState本身是一个异步的方法,它还有一个参数是回调函数。
以上这篇浅谈react.js中实现tab吸顶效果的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 再次谈论React.js实现原生js拖拽效果引起的一系列问题
- 再次谈论React.js实现原生js拖拽效果引起的一系列问题
- 转:jquery实现tab切换效果及js css ajax推荐
- 问题:关于坛友的一个js轮播效果的实现
- JS实现TAB标签效果
- js实现的简洁网页滑动tab菜单效果代码
- 简洁的JS实现Tab切换效果
- js实现淘宝首页图片轮播效果(修正图片滚动顺序的问题)
- JS+CSS实现滑动切换tab菜单效果
- js实现类似菜单风格的TAB选项卡效果代码
- JS实现TAB原理及效果
- js实现黑色简易的滑动门网页tab选项卡效果
- js tab效果的实现代码
- jquery插件tytabs.jquery.min.js实现渐变TAB选项卡效果
- js实现tab效果的源代码代码
- JS 简单实现Ext.TabPanel效果(转载)
- jquery插件tytabs.jquery.min.js实现渐变TAB选项卡效果
- js(JavaScript)代码实现的TAB标签切换效果
- JS+CSS实现滑动切换tab菜单效果