react如何实现导航栏二级联动
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,这篇文章给大家分享的是有关react如何实现导航栏二级联动的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下效果图js代码import { Component }
千家信息网最后更新 2025年01月18日react如何实现导航栏二级联动
这篇文章给大家分享的是有关react如何实现导航栏二级联动的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
具体内容如下
效果图
js代码
import { Component } from "react";import './scroll.less' class Scroll extends Component { constructor(...args) { super(...args) this.state = { list: [ { id: 1, title: '列表1' }, { id: 2, title: '列表2' }, { id: 3, title: '列表3' }, { id: 4, title: '列表4' }, { id: 5, title: '列表5' }, { id: 6, title: '列表6' }, { id: 7, title: '列表7' }, { id: 8, title: '列表8' }, { id: 9, title: '列表9' }, { id: 10, title: '列表10' }, { id: 11, title: '列表11' }, { id: 12, title: '列表12' }, { id: 13, title: '列表13' }, { id: 14, title: '列表14' }, { id: 15, title: '列表15' }, { id: 16, title: '列表16' }, { id: 17, title: '列表17' }, ], LeftList: [ { id: 1, title: '列表1', height: 800 }, { id: 2, title: '列表2', height: 600 }, { id: 3, title: '列表3', height: 500 }, { id: 4, title: '列表4', height: 900 }, { id: 5, title: '列表5', height: 450 }, { id: 6, title: '列表6', height: 300 }, { id: 7, title: '列表7', height: 900 }, { id: 8, title: '列表8', height: 1010 }, { id: 9, title: '列表9', height: 300 }, { id: 10, title: '列表10', height: 600 }, { id: 11, title: '列表11', height: 400 }, { id: 12, title: '列表12', height: 760 }, { id: 13, title: '列表13', height: 580 }, { id: 14, title: '列表14', height: 630 }, { id: 15, title: '列表15', height: 540 }, { id: 16, title: '列表16', height: 983 }, { id: 17, title: '列表17', height: 610 }, ], curr: 0,//存储下标 } // 默认添加一个 因为第一个的scrollTop值是0 this.LeftHeight = [0] // 滚动的开关 this.Swich = true } // 渲染完成获取每一个列表距离顶部的距离 componentDidMount() { // 定义为0 每次就可以循环加起来就是盒子距离顶部的距离 this.Height = 0 // 循环获取每一个的高 for (var i = 0; i < this.state.LeftList.length - 1; i++) { this.Height += this.state.LeftList[i].height // 将它添加到数组中 this.LeftHeight.push(this.Height) } } // 点击左侧列表 点击获取下标 fnTab(Ind) { // 点击的时候让右边的滚动事件为false this.Swich = false // 存储下标 this.setState({ curr: Ind }) // 根据下标取出数组中对应下标的scrollTop值 就让右边的scrollTop为数组中取出的值 this.refs['rightItem'].scrollTop = this.LeftHeight[Ind]; // this.refs.scrollLeft.scrollTop = this.state.curr - 4 * 58.89 } FnScroll() { // 监听滚动 this.scrollTop = this.refs['rightItem'].scrollTop // 这边用开关判断是否执行 if (this.Swich) { // 存放下标 let num = 0 // 循环取出数组中的数值 for (var i = 0; i < this.LeftHeight.length - 1; i++) { if (this.scrollTop >= this.LeftHeight[i]) { num = i } } // 存储下标 this.setState({ curr: num }) } // 判断滚动的值和数组中的值相等 开关为true if (this.scrollTop == this.LeftHeight[this.state.curr]) { setTimeout(() => { this.Swich = true; }); } } render() { return () }}export default Scroll{this.state.list.map((item, index) =>{item.title})}{this.state.LeftList.map((item) =>)}{item.title}
less代码
* { margin: 0; padding: 0;} .box { width: 100vw; height: 100vh; background: red; .scroll { width: 100vw; height: 100vh; display: flex; // 右边列表 .scroll-right { width: 25vw; background: aqua; font-size: 28px; height: 100vh; overflow-y: auto; .right-item { width: 25vw; height: 80px; text-align: center; line-height: 80px; border-bottom: 1px solid #ccc; } .active { height: 80px; text-align: center; line-height: 80px; background: #0f0; } } // 左边内容 .scroll-left { width: 75vw; height: 100vh; overflow-y: auto; //滚动的更加丝滑 scroll-behavior: smooth; .left-item { width: 75vw; font-size: 30px; text-align: center; .item-title { height: 30px; background: #ccc; } } } }}
感谢各位的阅读!关于"react如何实现导航栏二级联动"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
下标
数组
内容
右边
存储
循环
导航
代码
更多
篇文章
顶部
不错
实用
事件
就是
效果
效果图
数值
文章
时候
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
智能互联网络技术是什么科
网络安全人才奖推选
字节跳动服务器硬件招聘
es是关系型数据库还是非
svn服务器创建分支
惠普服务器硬盘价格
5年软件开发去国企好吗
网络安全一般是做什么的
行长 网络安全周 讲话
vivo软件开发要什么文凭
连云港江苏服务器服务商云空间
移动网络技术工资多少
二调数据库入库
小学生网络安全小故事
无锡技术管理软件开发平台
携程网络技术上海有限公司
微软神经网络技术
网络安全技术论坛排名
c null插入数据库
湖北中小学生家庭教育及网络安全
查看服务器当前目录磁盘和内存
实时语音需要服务器中转么
长沙澳博软件开发有限公司官网
互联网与我们的生活科技手抄报
互联网科技创新的方法路径
软件开发中的qa
5G超密集网络技术
asce 数据库
vxworks软件开发套件
衢州至金华火车数据库