使用JavaScript实现楼层导航的方法及过程是什么
Admin 2022-06-24 群英技术资讯 1190 次浏览
这篇文章给大家介绍了“使用JavaScript实现楼层导航的方法及过程是什么”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。<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>
<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>
点击左侧菜单中的楼层按钮对应跳转到相应的楼层。
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;
}
}
楼层监听,页面卷动时,左侧菜单中的楼层栏目背景随之变化。
// 页面卷动时,左侧盒子栏目背景随之变化
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 = '';
}
}
}
}

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了react fiber执行原理示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
这篇文章主要介绍了JavaScript字典与集合详解,集合是由一组无序且不重复的元素构成。我们可以将集合看成一种特殊的数组,它的特殊之处就是无序且不重复,这也就意味着我们不能通过下标的方式进行访问,而且集合中不会出现重复的元素
这篇文章主要给大家分享是JavaScript中的延迟加载属性的内容,下文对延迟加载属性模式有详细的介绍及示例,有这方面学习需要的朋友可以参考,下面我们一起来学习一下。
这篇文章主要介绍了Vue3内置组件Teleport使用方法,Teleport是Vue 3.0 新增的一个内置组件,主要是为了解决一些特殊场景下模态对话框组件、组件的渲染,带着些许的了解一起走进下面文章的详细内容吧
这篇文章主要介绍了vue使用watch监听器的基本使用方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008