文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么使用Javascript开发sliding-nav带滑动条效果的导航插件

2023-06-14 09:10

关注

小编给大家分享一下怎么使用Javascript开发sliding-nav带滑动条效果的导航插件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

一、前言

效果如下图:

怎么使用Javascript开发sliding-nav带滑动条效果的导航插件

二、使用方法

本插件只需要如下的三步,就可以在您的项目中使用:

在</body>标记结束前,引用sliding-nav.js文件

在需要滑动条的菜单容器上加类名 sliding-nav,当前项使用类名:active

使用属性来定定外观:sn-color="颜色" sn-radius="圆度" sn-height="高度"

<script src="/path/to/sliding-nav.js"></script><ul class="nav sliding-nav" sn-color="#F00" sn-radius="0px" sn-height="3px"> <li class="active">菜单项1</li> <li>菜单项2</li> <li>菜单项3</li><ul>

三、开发过程

1. 模型示例

怎么使用Javascript开发sliding-nav带滑动条效果的导航插件

导航菜单一般使用上图的层次型结构,外层容器使用<ul> 标记,菜单项使用<li>标记,假设如果要显示黄色小横条,如何定位很重要。

经过分析,虽然在视觉上小横条位于UL之内,为了不破坏原来导航的样式,小黄条必须使用absolute的绝对定位,并且初始位置与ul标记相同。

因此,我们把小横条插入<ul>标记的前面,如上面的小灰点,它就是小横条的初始位置即(left=0,top=0)的位置。

那么我们如何让小条看起来在菜单项的正下方呢?

实现上面的功能可以使用如下的代码:

function init() {  var navs = document.getElementsByClassName('sliding-nav');  for (var i = 0; i < navs.length; i++) {    //创建一个DIV与当前导航竖向对齐  var indi = document.createElement("div");  indi.id = "slna-indicator"   indi.style.borderRadius = navs[i].getAttribute("sn-radius") || "0px"  indi.style.height = navs[i].getAttribute("sn-height") || "3px"  indi.style.backgroundColor = navs[i].getAttribute("sn-color") || "#F00"   indi.style.position = "absolute"  indi.style.transition = "0.5s"   //查找当前子菜单项,如果有类名active或者是selected就视为当前项,如果没有使用第1项  var selected = navs[i].getElementsByClassName('active')  if (selected.length == 0) {   selected = navs[i].getElementsByClassName('selected')  }  if (selected.length == 0) {   selected = navs[i].children  }   if (selected.length == 0) {   throw Error('Sorry, Navigation bar has no item at all!');  }   selected = selected[0];   indi.style.width = selected.offsetWidth + "px";  indi.style.top = selected.offsetHeight + "px";  indi.style.left = selected.offsetLeft + "px";  navs[i].parentElement.insertBefore(indi, navs[i]);   //未完成,下面插入代码以绑定事件  } }

如上的代码构建了初始化函数init(),此函数:

查找所有含有类名sliding-nav的标记,并且按照上面的方法,在前面插入div标记充当“指示条”,并且查找“活动”的菜单项,找到后通过这个菜单项的各个属性给“指示条”定位。

2、事件与动画

我们把"指示条"div 标记transition属性设置成了0.5s,那么只要在事件里直接设置该div的如下:

所以可以在如上的代码末尾,插入如下的代码实现事件与动画:

for (var j = 0; j < navs[i].children.length; j++) {   hover(navs[i].children[j], function(e, elem) {    indi.style.width = elem.offsetWidth + "px";    indi.style.left = elem.offsetLeft + "px";   });   //移出导航就恢复默认   hover(navs[i], null, function(e, elem) {    indi.style.width = selected.offsetWidth + "px";    indi.style.left = selected.offsetLeft + "px";   });  }

其中代码,用到了自定义函数hover,该函数类似于实现hover事件,JS原生只有mouseover和mouseout事件。

函数作用是给DOM元素绑定鼠标移入和鼠标移出事件,具体实现的过程,可以看作者原代码。

四、所有原代码

本文实现的所有原代码如下,希望读者提出更加优化的建议,我们一起打造更加唯美的前端体验。

for (var j = 0; j < navs[i].children.length; j++) {   hover(navs[i].children[j], function(e, elem) {    indi.style.width = elem.offsetWidth + "px";    indi.style.left = elem.offsetLeft + "px";   });   //移出导航就恢复默认   hover(navs[i], null, function(e, elem) {    indi.style.width = selected.offsetWidth + "px";    indi.style.left = selected.offsetLeft + "px";   });  }

以上是“怎么使用Javascript开发sliding-nav带滑动条效果的导航插件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯