react.js中如何实现tab吸顶效果
发表于:2025-12-01 作者:千家信息网编辑
千家信息网最后更新 2025年12月01日,这篇文章主要介绍"react.js中如何实现tab吸顶效果"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"react.js中如何实现tab吸顶效果"文章能帮助大
千家信息网最后更新 2025年12月01日react.js中如何实现tab吸顶效果
这篇文章主要介绍"react.js中如何实现tab吸顶效果"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"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( ) } }然后我发现这样写有问题,当我滚动条滚动距离达到条件时,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吸顶效果"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
效果
吸顶
方法
问题
知识
就是
属性
行业
页面
顶部
不同
实用
代码
位置
内容
函数
办法
参数
实用性
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络技术招聘上海
武汉软件开发人工费用标准
学校网络安全设备说明
湖南省公共信息网络安全电话
荒野乱斗保护服务器是什么意思
最新仙境传说ro服务器列表
网络安全图标visio
网络安全保卫大队辅警职责
服务器尚未打开
广东专业软件开发哪家便宜
wincc的数据库
违反网络安全向哪些部门举报
csgo怎么设置中国服务器代码
java 数据库分页缓存
域名服务器存放
项目服务器的规划
数据库应用技术小论文
徐汇区特殊软件开发代理品牌
2005数据库有多大
盐湖数据库
杭州追梦人网络技术有限公司招聘
抖音小程序用什么软件开发
1995信息网络安全问题
幻塔最新服务器是哪个区
软件开发报价包含
肇庆电商软件开发费用是多少
云服务器广东
java 数据库分页缓存
2021互联网科技股
数据库主键为何不为空