react如何实现导航栏二级联动
发表于:2024-11-29 作者:千家信息网编辑
千家信息网最后更新 2024年11月29日,这篇文章给大家分享的是有关react如何实现导航栏二级联动的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下效果图js代码import { Component }
千家信息网最后更新 2024年11月29日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安全错误
数据库的锁怎样保障安全
对数据库字段描述不正确的是
安卓软件开发试卷
it 软件开发
对数据库进行备份并命名
南通 首信网络技术
人工智能网络安全工程师
锐盛互联网科技
腾讯网络安全赛事
网络安全设备产品认证目录
山东安卓软件开发哪家好
德国大众id软件开发
有名的网络技术咨询参考价格
洗车行如何建立客户数据库
精准数据库营销系统
网络安全与文明上网主题班会
网络安全统一清查
宁夏哪些学校有软件开发
维普数据库检索流程
数据库基础与应用作业帮做
dbf数据库在哪
erp和软件开发发展方向
服务器共享卡顿
徐汇区网络视频系统服务器
达内软件开发靠谱吗
黄浦区正规网络技术售后保障
安徽大专网络安全技能大赛
长城汽车底层软件开发岗
网络技术岗位认知
网络安全法保证安全技术措施
云计算单台服务器收入