「组件」侧边hover锚点导航双向绑定

昔不亏
• 阅读 1367

样式如图: 「组件」侧边hover锚点导航双向绑定 1:在components文件夹下新建SideAnchorNav.vue

<template>
    <div class="sideAnchorNav">
        <div class="left-nav" :class="navText?'navHover':''" @mouseenter="navText=true" @mouseleave="navText=false"></div>
        <ul class="nav-link" @mouseenter="navText=true" @mouseleave="navText=false">
            <li class="nav" :class="index==activeMenu?'anchorNavSelect':''" v-for="(item,index) in allMenuList" :key='index'
             @click="jump(index)"><a href="javascript:void(0)"><span :class="index==activeMenu||navText?'spanHover':''">{{item}}</span></a></li>
        </ul>
    </div>
</template>

<script>
    export default {
        data() {
            return {
                navText: false,
                scroll: null,
                activeMenu: null,
            }
        },
        props: ['allMenuList'],//!!!注意
        mounted() {
            window.addEventListener('scroll', this.dataScroll);
        },
        watch: {
            scroll: function() {
                this.loadSroll()
            }
        },
        methods: {
            dataScroll: function() {
                this.scroll = document.documentElement.scrollTop || document.body.scrollTop;
            },
            jump(index) {
                this.activeMenu = index
                let jump = document.getElementsByClassName('section');//!!!注意
                let total = jump[index].offsetTop;
                document.body.scrollTop = total;
                document.documentElement.scrollTop = total - 70;
                window.pageYOffset = total;
            },
            loadSroll: function() {
                var self = this;
                var navs = document.getElementsByClassName('nav')
                var sections = document.getElementsByClassName('section');//!!!注意
                for (var i = 0; i < sections.length; i++) {
                    if (self.scroll >= sections[i].offsetTop - 200) {
                        this.activeMenu = i
                    }
                    if (self.scroll == 0) {
                        this.activeMenu = null
                    }
                }

            },
        }
    }
</script>

<style lang="scss">
    .sideAnchorNav {
        .left-nav {
            height: 100%;
            width: 500px;
            position: fixed;
            top: 0;
            left: -250px;
            z-index: 10;
        }

        .navHover {
            background-image: linear-gradient(to right, rgba(0, 0, 0, 1), rgba(0, 0, 0, 0.2));
            filter: blur(40px);
        }

        .nav-link {
            position: fixed;
            left: 3%;
            top: 35%;
            z-index: 1;
            color: white;
            z-index: 20;
        }

        .nav {
            a {
                color: white;
                font-size: 16px;
            }

            opacity: 0.6;
            line-height: 1;

            span {
                opacity: 0;
                transition: all 0.5s;
            }

            span:hover {
                text-decoration: underline;

            }

            .spanHover {
                line-height: 3;
                opacity: 1;
            }
        }

        .anchorNavSelect {
            opacity: 1;
            border: none;

            a {
                color: orange;
            }
        }
    }
</style>

2:在需要使用的页面中

<SideAnchorNav :allMenuList="this.allMenuList"></SideAnchorNav>
import SideAnchorNav from '@/components/SideAnchorNav .vue'
components: { SideAnchorNav },
allMenuList: ['SAP 产品', 'PA全球顾问认证', '教育培训资源', '教育培训解决方案'],//!!!自行更改
在相对应的div上加class="section",
点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Souleigh ✨ Souleigh ✨
2年前
前端性能优化 - 雅虎军规
无论是在工作中,还是在面试中,web前端性能的优化都是很重要的,那么我们进行优化需要从哪些方面入手呢?可以遵循雅虎的前端优化35条军规,这样对于优化有一个比较清晰的方向.35条军规1.尽量减少HTTP请求个数——须权衡2.使用CDN(内容分发网络)3.为文件头指定Expires或CacheControl,使内容具有缓存性。4.避免空的
昔不亏 昔不亏
3年前
「组件」返回顶部按钮
样式如图1:在components文件夹下新建BackTop.vuejs<template<divclass"backTopBtn"<ahref"javascript:;"<divvif"btnFlag"class"btn"@click"backTop"TOP</div
Stella981 Stella981
2年前
AndroidStudio封装SDK的那些事
<divclass"markdown\_views"<!flowchart箭头图标勿删<svgxmlns"http://www.w3.org/2000/svg"style"display:none;"<pathstrokelinecap"round"d"M5,00,2.55,5z"id"raphael
Wesley13 Wesley13
2年前
thinkphp3.2.3模板渲染支持三元表达式
thinkphp3.2.3模板渲染支持三元表达式{$status?'正常':'错误'}{$info'status'?$info'msg':$info'error'}注意:三元运算符中暂时不支持点语法。如下:           <divclass"modalhidefade"id'myModa
Stella981 Stella981
2年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这