html tab顶部吸附,浅谈react.js中实现tab吸顶效果的问题
发布日期:2021-06-24 15:58:35 浏览次数:3 分类:技术文章

本文共 1396 字,大约阅读时间需要 4 分钟。

在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(

)

}

}

然后我发现这样写有问题,当我滚动条滚动距离达到条件时,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吸顶效果的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

时间: 2017-09-03

转载地址:https://blog.csdn.net/weixin_33682804/article/details/118007395 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:python画图猪_用Python的turtle画一只小猪乔治【刚学python两天,记念一下】
下一篇:html把分页改成滚动条,基于JavaScript实现表格滚动分页

发表评论

最新留言

路过,博主的博客真漂亮。。
[***.116.15.85]2024年04月19日 16时54分43秒