功能为右侧描点导航,点击后内容滚动到指定位置,监听滚动条,右边描点导航高亮
效果图:
组件封装 PointTags
<template> <div class="point-wrap"> <el-tabs tab-position="right" v-model="activeTag" size="middle" @tab-click="tabHandle"> <el-tab-pane :key="item.id" v-for="item in tagsList" :label="item.label" :name="item.id"></el-tab-pane> </el-tabs> </div> </template> <script> export default { name: "", data () { return { }; }, props: { tagsList:{ type : Array, default: () => [] }, activeTag:{ type : String, default: () => '' } }, mounted () { this.activeTag = this.tagsList[0].id }, methods:{ tabHandle(tag){ this.$emit('activeTagHandle',tag.name) } } }; </script>
父级调用
<div ref='userPanel'> // 这里存放你的内容以id定位描点 </div> <!-- 描点导航 --> <point-tags class="point-wrap" :tags-list="tagsList" :activeTag="activeTag" @activeTagHandle="activeTagHandle" ></point-tags> data() { return { activeTag: '', tagsList: [ { label: '基本信息', id: 'tag1', }, { label: '认证结果', id: 'tag2', }, { label: '技能项评分', id: 'tag3', }, { label: '优势', id: 'tag4', }, { label: '待改进项', id: 'tag5', }, ], } } // 监听滚动条 mounted() { this.$nextTick(() => { this.$refs.userPanel.addEventListener('scroll', this.onScroll,true) }) }, methods: { onScroll(e) { // 这里替换成你内容item的class let scrollItems = document.querySelectorAll(".wrap") for (let i = scrollItems.length - 1; i >= 0; i--) { // 判断滚动条滚动距离是否大于当前滚动项可滚动距离 let judge = e.target.scrollTop >= scrollItems[i].offsetTop - scrollItems[0].offsetTop - 20; if (judge) { this.activeTag = this.tagsList[i].id; break; } } }, activeTagHandle(domId){ //页面滚动了的距离 let ele = this.$refs.userPanel let height = ele.scrollTop //指定dom到页面顶端的距离 let dom = document.getElementById(domId); let domHeight = dom.offsetTop - 20; //滚动距离计算 var S = Number(height) - Number(domHeight); //判断上滚还是下滚 if(S<0){ //下滚 S = Math.abs(S); ele.scrollBy({ top: S, behavior: "smooth" }); }else if(S==0){ //不滚 ele.scrollBy({ top: 0, behavior: "smooth" }); }else{ //上滚 S = -S ele.scrollBy({ top: S, behavior: "smooth" }); } }, }
标签:scrollItems,滚动,label,ul,let,描点,element,id From: https://www.cnblogs.com/hpx2020/p/17083733.html