使用JavaScript实现楼层导航的方法及过程是什么
Admin 2022-06-24 群英技术资讯 916 次浏览
这篇文章给大家介绍了“使用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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
generator函数是JS引擎中使用的结构函数,不提供给开发者。由构造函数generator创建的对象是迭代器和可迭代对象。
这篇文章给大家分享的是有关vue三级联动实现的内容,具体介绍了省市区三级联动的实现以及代码,小编觉得比较有趣,因此分享给大家做个参考,感兴趣的朋友就跟随小编一起来看看吧。
如果调用者在函数返回时能够获得预期结果(即获得预期返回值或看到预期效果),则该函数同步。如果函数同步,即使调用函数执行的任务耗时,也会等到得到预期的结果。
这篇文章主要介绍了Vue实现圆环进度条的示例,帮助大家更好的理解和使用前端框架进行开发,感兴趣的朋友可以了解下
这篇文章主要介绍了解决vant title-active-color与title-inactive-color不生效问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
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