温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

JavaScript如何制作楼层导航效果

发布时间:2021-10-19 17:06:01 来源:亿速云 阅读:185 作者:小新 栏目:开发技术

这篇文章将为大家详细讲解有关JavaScript如何制作楼层导航效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

    1. 功能实现

    1.1 结构层

    <div id="box" class="box">
        <ul class="list">
            <li class="content-part" data-n="栏目一">栏目一</li>
            <li class="content-part" data-n="栏目二">栏目二</li>
            <li class="content-part" data-n="栏目三">栏目三</li>
            <li class="content-part" data-n="栏目四">栏目四</li>
            <li class="content-part" data-n="栏目五">栏目五</li>
        </ul>
    </div>
    <div class="left">
        <ul id="left-list">
            <li data-n="栏目一">栏目一</li>
            <li data-n="栏目二">栏目二</li>
            <li data-n="栏目三">栏目三</li>
            <li data-n="栏目四">栏目四</li>
            <li data-n="栏目五">栏目五</li>
        </ul>
    </div>

    1.2 样式层

    <style>
        * {
            margin: 0;
            padding: 0;
        }
        body .box {
            width: 1200px;
        }
        body .box {
            margin: 0 auto;
        }
        ul {
            list-style: none;
        }
        body .box ul li {
            height: 800px;
            background-color: silver;
            margin-bottom: 20px;
            font-size: 30px;
            font-weight: bold;
        }
        body .left {
            position: fixed;
            left: 20px;
            bottom: 100px;
            width: 100px;
            height: 250px;
            top: 50%;
            margin-top: -125px;
            background-color: silver;
        }
        body .left ul li {
            height: 50px;
            line-height: 50px;
            text-align: center;
            cursor: pointer;
        }
        body .current {
            color: #fff;
            background-color: tomato;
        }
    </style>

    1.3 行为层

    1.3.1 楼层跳转

    点击左侧菜单中的楼层按钮对应跳转到相应的楼层。

    var oList = document.getElementById('left-list');
    // 点击事件委托
    oList.onclick = function (e) {
        if (e.target.tagName.toLowerCase() == 'li') {
            // 取data-n值
            var n = e.target.getAttribute('data-n');
            // []属性选择器
            var contentPart = document.querySelector('.content-part[data-n=' + n + ']');
            // 设置卷动
            document.documentElement.scrollTop = contentPart.offsetTop;
        }
    }
    1.3.2 楼层监听

    楼层监听,页面卷动时,左侧菜单中的楼层栏目背景随之变化。

    // 页面卷动时,左侧盒子栏目背景随之变化
    var contents = document.querySelectorAll('.content-part');
    var lis = document.querySelectorAll('#left-list li');
    var offsetTopArr = [];
    for (var i = 0; i < contents.length; i++) {
        offsetTopArr.push(contents[i].offsetTop);
    }
    // 为了方便比较,追加无穷大
    offsetTopArr.push(Infinity);
    // 监听卷动
    var nowFloor = -1;
    window.onscroll = function (e) {
        var nowScrollTop = document.documentElement.scrollTop;
        // break的i值即为盒子数组下标
        for (var i = 0; i < offsetTopArr.length; i++) {
            if (nowScrollTop >= offsetTopArr[i] && nowScrollTop < offsetTopArr[i + 1]) {
                break;
            }
        }
        // 楼层不等,进行样式更改
        if (nowFloor != i) {
            nowFloor = i;
            for (var j = 0; j < lis.length; j++) {
                if (j == i) {
                    // 当前楼层添加样式
                    lis[j].className = 'current';
                } else {
                    // 去掉其他楼层的样式
                    lis[j].className = '';
                }
            }
        }
    }

    2. 效果预览

    JavaScript如何制作楼层导航效果

    关于“JavaScript如何制作楼层导航效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI