Vue中的element tabs点击锚点定位,鼠标滚动定位
更新时间:2024年07月24日 10:22:37 作者:李泽举
这篇文章主要介绍了Vue中的element tabs点击锚点定位,鼠标滚动定位方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
一、效果图
二、代码
- html
<el-tabs class="customer-tab" type="card" @tab-click="jump" v-model="tabName" > <el-tab-pane v-for="(tab, index) in tabs" :name="tab.refName" :key="index" :label="tab.name" ></el-tab-pane> </el-tabs> <div class="scroll-content" @scroll="onScroll" :style=" 'overflow-x: hidden; overflow-y: auto;height:' + contentStyleObj.height " > <!-- 用户管理 --> <div :ref="tabs[0].refName" class="scroll-item"> <div class="line-name"> <h2>{{ tabs[0].name }}</h2> </div> <div> <p style="height: 40px" v-for="item in [ 0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, ]" :key="item" > 待发货符合规范化如故 </p> </div> </div> <!-- 配置管理 --> <div :ref="tabs[1].refName" class="scroll-item"> <div class="line-name"> <h2>{{ tabs[1].name }}</h2> </div> <div> <p style="height: 40px" v-for="item in [ 0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, ]" :key="item" > 新能说出的基本功发到你DNF不得发布 </p> </div> </div> <!-- 角色管理 --> <div :ref="tabs[2].refName" class="scroll-item" style="padding-top: 1rem; top: 5px" > <div class="line-name"> <h2>{{ tabs[2].name }}</h2> </div> <div> <p v-for="item in [ 0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, ]" :key="item" > 新水泥厂剧场版 </p> </div> </div> <!-- 角色管理2 --> <div :ref="tabs[3].refName" class="scroll-item" style="padding-top: 1rem; top: 5px" > <div class="line-name"> <h2>{{ tabs[3].name }}</h2> </div> <div> <p v-for="item in [ 0, 1, 2, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, ]" :key="item" > 新水泥厂剧场版 </p> </div> </div> </div>
- js
<script> export default { name: 'index', props: {}, components: {}, data() { return { tabIndex: '0', contentStyleObj: { height: '100px', }, tabName: 'setOneRef', tabs: [ { name: '用户管理', refName: 'setOneRef', }, { name: '配置管理', refName: 'setTwoRef', }, { name: '角色管理', refName: 'setThreeRef', }, { name: '角色管理2', refName: 'setFourRef', }, ], } }, computed: {}, watch: {}, created() { this.getHight() window.addEventListener('resize', this.getHight) }, destroyed() { window.removeEventListener('resize', this.getHight) }, methods: { // tab click jump(tab, event) { let target = document.querySelector('.scroll-content') let scrollItems = document.querySelectorAll('.scroll-item') // 判断滚动条是否滚动到底部 if (target.scrollHeight <= target.scrollTop + target.clientHeight) { this.tabIndex = tab.index.toString() } let totalY = scrollItems[tab.index].offsetTop - scrollItems[0].offsetTop // 锚点元素距离其offsetParent(这里是body)顶部的距离(待滚动的距离) let distance = document.querySelector('.scroll-content').scrollTop // 滚动条距离滚动区域顶部的距离 // let distance = document.body.scrollTop || document.documentElement.scrollTop || window.pageYOffset // 滚动条距离滚动区域顶部的距离(滚动区域为窗口) // 滚动动画实现, 使用setTimeout的递归实现平滑滚动,将距离细分为50小段,10ms滚动一次 // 计算每一小段的距离 let step = totalY / 50 if (totalY > distance) { smoothDown(document.querySelector('.scroll-content')) } else { let newTotal = distance - totalY step = newTotal / 50 smoothUp(document.querySelector('.scroll-content')) } // 参数element为滚动区域 function smoothDown(element) { if (distance < totalY) { distance += step element.scrollTop = distance setTimeout(smoothDown.bind(this, element), 10) } else { element.scrollTop = totalY } } // 参数element为滚动区域 function smoothUp(element) { if (distance > totalY) { distance -= step element.scrollTop = distance setTimeout(smoothUp.bind(this, element), 10) } else { element.scrollTop = totalY } } }, // 滚动条滚动 onScroll(e) { let scrollItems = document.querySelectorAll('.scroll-item') for (let i = scrollItems.length - 1; i >= 0; i--) { // 判断滚动条滚动距离是否大于当前滚动项可滚动距离 let judge = e.target.scrollTop >= scrollItems[i].offsetTop - scrollItems[0].offsetTop - 400 if (judge) { this.tabIndex = i.toString() // 找对应的tab-name值 this.tabName = this.tabs[this.tabIndex].refName break } } }, getHight() { this.contentStyleObj.height = window.innerHeight - 190 + 'px' }, }, } </script>
- css
<style lang="scss" scoped> ::v-deep.customer-tab { width: 100%; height: 50px; background-color:#f5f7fa; padding: 4px; } ::v-deep.el-tabs--card > .el-tabs__header { border-bottom: none; margin: 0; .el-tabs__nav { width: 100%; display: flex; justify-content: space-around; border: none; .el-tabs__item { width: 25%; text-align: center; border: none; } .is-active { border-radius: 4px; background-color: #005BD9; color: #fff; } } } </style>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue中computed、methods与watch的区别总结
这篇文章主要给大家介绍了关于Vue中computed、methods与watch区别的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Vue具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧2019-04-04uniapp 小程序和app map地图上显示多个酷炫动态的标点效果(头像后端传过来)
这篇文章主要介绍了uniapp 小程序和app map地图上显示多个酷炫动态的标点效果(头像后端传过来),本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-09-09Vue3+Element-plus项目自动导入报错的解决方案
vue3出来一段时间了,element也更新了版本去兼容vue3,下面这篇文章主要给大家介绍了关于Vue3+Element-plus项目自动导入报错的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-07-07vue3使用别名报错问题的解决办法(vetur插件报错问题)
最近在写一个购物网站使用vue,使用中遇到了问题,下面这篇文章主要给大家介绍了关于vue3使用别名报错问题的解决办法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2022-07-07
最新评论