zoukankan      html  css  js  c++  java
  • react.js中实现tab吸顶效果问题

    在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本身是一个异步的方法,它还有一个参数是回调函数。

    但我无法将这个错误点具体讲清楚,不知道碰巧看到这篇blog的各位能否指点一下(感谢)。

  • 相关阅读:
    2015-05-27 用正则把oracle时间转化到mysql时间
    linux版idea14界面美观和windows,mac基本一致
    ubuntu 下自定义快捷键,,用着舒服
    ubuntu 方便好用的截图软件
    Integer 包装器类 大小比较
    win7、ubuntu双系统,遇到分区不可用问题,和卸载ubuntu后win7开不了机
    巧妙小思想
    读取16进制文件和校验图片格式的问题。 文件名后缀
    旧电脑变废为宝!
    Win10打开Autodesk软件时提示“管理员已阻止你运行此应用”
  • 原文地址:https://www.cnblogs.com/minz/p/7481915.html
Copyright © 2011-2022 走看看