利用JQuery实现顶部导航栏功能

今天给大家介绍一下,如何利用JQuery实现顶部导航栏功能。其实原理很简单就是利用css和JQuery样式选择器实现的。

下面举个例子具体介绍一下如何这些功能,案例如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>jQuery三级下拉列表导航菜单</title>

<script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>

<style type="text/css">
*{margin: 0; padding: 0;}
body{ font-size: 12px; }
li{ list-style: none;}
ul.nav li{ width: 200px; text-align:center;}
ul.nav > li{ float: left; margin-right:10px;}
ul.nav li h3{height: 40px; line-height: 40px;}
ul.nav > li > h3{ background: #72a7ff;}
ul.nav > li > ul > li h3{ background: #ffd9d9;}
ul.nav > li h3:hover,.choice{ background: #ffc0c0!important;}
ul > li > ul{ display: none;}
ul > li.on > ul{ display: block;}
ul.nav li{ position: relative;}
ul.nav > li > ul > li ul{ position:  absolute; top: 0; right: -200px;}
ul.nav span.sub{ position: absolute; display: block; right:10px; top: 0; width: 10px; height: 40px; background: url(images/arrows.png) no-repeat center center;}
</style>

<script type="text/javascript">
    $(document).ready(function() {
        $("ul.nav li").hover(function(){
            $(this).addClass("on");

        },
        function(){
            $(this).removeClass("on");

        })
    });

    $(document).ready(function() {
        $("ul.nav li").hover(function(){
            $(this).parent("ul").siblings("h3").addClass("choice");

        },
        function(){
            $(this).parent("ul").siblings("h3").removeClass("choice");
        })
    });

    $(document).ready(function() {       
            if ($("ul.nav li").find("ul") .html()!="") {
                $("ul.nav li").parent("ul").siblings("h3").append("<span class='sub'></span>");                
            }
    });
</script>


</head>
<body>
<ul class="nav">
  <li><h3>我的网站</h3>
    <ul>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3>
              <ul>
                <li><h3>4级分类</h3>
                  <ul>
                    <li><h3>5级分类</h3></li>
                    <li><h3>5级分类</h3></li>
                    <li><h3>5级分类</h3></li>
                    <li><h3>5级分类</h3></li>
                  </ul>
                </li>
                <li><h3>4级分类</h3></li>
                <li><h3>4级分类</h3></li>
                <li><h3>4级分类</h3></li>
              </ul>
            </li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
    </ul>
  </li>
  <li><h3>我的网站</h3>
    <ul>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
    </ul>
  </li>
  <li><h3>我的网站</h3>
    <ul>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
    </ul>
  </li>
  <li><h3>我的网站</h3>
    <ul>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
        <li><h3>2级分类</h3>
          <ul>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
            <li><h3>3级分类</h3></li>
          </ul>
        </li>
    </ul>
  </li>
</ul>
</body>
</html>

运行截图:

实现思路:

1.首先利用css将二级三级菜单隐藏起来。

2.然后利用Jquery实现对菜单的显示和隐藏。

如果对文章有什么疑义或者有啥问题都可以找我交流QQ:208017534 欢迎打扰!!!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏文武兼修ing——机器学习与IC设计

基于sklearn的线性支持向量机分类器原理代码实现

原理 分类器 机器学习的分类器,均可以看成一个或一组超平面,将label不同的数据点在数据空间中分开。对于线性可分问题,属于相同label的数据点在数据空间中可...

3639
来自专栏AI科技大本营的专栏

深度学习目标检测指南:如何过滤不感兴趣的分类及添加新分类?

AI 科技大本营按:本文编译自 Adrian Rosebrock 发表在 PyImageSearch 上的一篇博文。该博文缘起于一位网友向原作者请教的两个关于目...

872
来自专栏贾志刚-OpenCV学堂

OpenCV中几何形状识别与测量

OpenCV中几何形状识别与测量 ---- 写有代码的文章、做有情怀的人 ---- 经常看到有学习OpenCV不久的人提问,如何识别一些简单的几何形状与它们的颜...

64211
来自专栏机器学习养成记

聚类(二):k-means算法(R&python)

聚类算法属于无监督的机器学习算法,即没有类别标签y,需要根据数据特征将相似的数据分为一组。k-means为聚类算法中最简单、常见的一种,通过计算距离,将相似性高...

3677
来自专栏机器学习实践二三事

Image Style Transfer Using Convolutional Neural Network(理论篇)

今天这篇是关于neual art的,也就是style transfer算法; 文章来源: A Neural Algorithm of Artistic ...

3247
来自专栏null的专栏

深度学习算法原理——Softmax Regression

一、Logistic回归简介 image.png image.png 二、Softmax回归 2.1、Softmax回归简介 image.png 2.2、Sof...

5146
来自专栏Ldpe2G的个人博客

仿射变换实现组合操作 抠图+缩放+旋转

963
来自专栏用户2442861的专栏

概率论-最大似然估计

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/d...

601
来自专栏机器学习算法全栈工程师

从0到1 实现YOLO v3 (Part one)

如果说非要提供一个方法快速掌握目标检测的深度学习算法的话,那就是自己从无到有的实现它,在这期间,可以对整个算法有更清晰的认识,此次系列文章旨在提供一个自己从无到...

3256
来自专栏fangyangcoder

使用颜色空间进行图像分割

原文地址:https://realpython.com/python-opencv-color-spaces/

2053

扫码关注云+社区