三种方式实现网页二级菜单

三种方式实现网页二级菜单方法一:使用HTML和CSS实现 首先是Html代码,习惯上会将菜单放在一个div里,使用盒子模型,方便以后的操作和设置样式。二级菜单也就是在一级菜单中的li中再添加一个ul-li结构 <divclass="test"> <ul> <li>A</li> <li>B&lt..

大家好,又见面了,我是你们的朋友全栈君。

方法一:使用HTML和CSS实现

 

首先是Html代码,习惯上会将菜单放在一个div里,使用盒子模型,方便以后的操作和设置样式。

二级菜单也就是在一级菜单中的li中再添加一个ul-li结构

 

<div class="test">
	<ul>
        	<li>A</li>
            	<li>B</li>
            	<li>C
                 	<ul>
                    		<li>C1</li>
                    		<li>C2</li>
                    		<li>C3</li>
                	</ul>
           	</li>
 	</ul>
</div>

 

 

 

 

 

 

使用css代码设置样式

 

<style type="text/css">
        .test ul{
            list-style-type: none;

        }

        .test ul li{

            float:left;

            /*以下设置仅为方便查看效果*/
            width:50px;
            height:20px;
            border:1px solid black;
            text-align: center;
        }

        .test ul li ul{
            display: none;
        }

        .test li:hover ul{
            display:block;
        }

</style>

 

 

 

 

 

解释三个重要的css代码:

 

1.写出一个ul-li菜单时,它会默认垂直排列,而我们需要的是水平的菜单栏,所以需要设置li的浮动:float:left

2.当鼠标悬浮在有二级菜单的一级菜单选项时,才会出现二级菜单,所以在鼠标不悬浮的情况下,需要把二级隐藏起

来display:none

3.最后,设置li :hover ul 这个意思是,当鼠标悬浮在li上时,li下的ul呈现状态,hover是悬浮的意思,在设置a标签样

式时应该会接触过

 

 

 

方法二:使用jQuery实现

 

要用到jQuery首先第一步就是引入jquery.js文件

<script type=”text/javascript” src=”js/jquery-1.7.min.js”></script>

 

在平时做网页项目时,最好是将css,html,js分开,在html页面中引入css和js文件,css文件引入放在head中,js放在body的最后,这是为了在加载网页时,先加载出它的样式,最后加载js动态。那么注意了,在这里如果你的js代码是放在body中,那么引入jquery文件必须放在js代码之前,浏览器编译html文件时,是从上自下编译的,如果jquery文件放在最后,那么在你的js代码又使用到了jquery的功能,后果可想而知,效果是出不来的。

 

下面两种方式都是可行的,第一种二级菜单出现的很直接,fade呢有一个渐入渐出的过程

200,300的都是时间,估计是以ms为单位,有待查验。

 

js代码:

 

<script type="text/javascript">
        /* js 语句 $(function(){});*/
        $(function(){
            $(".test li").hover(
                    /*找父亲(li)下面的ul*/
                    function() {
                        $(this).find("ul").show(200);
                    },function(){
                        $(this).find("ul").hide(300);
                    }
            );

            $(".test li").hover(
                    function(){
                        $(this).find("ul").fadeIn(300);
                    },function(){
                        $(this).find("ul").fadeOut(300);
                    }
            );
        });
</script>

 

 

 

 

 

 

 

方法三:使用Bootstrap实现

 

如果不了解Bootstrap是什么,出门找百度咨询一下

 

和jquery类似的,需要引入三个文件:

1. bootstrap.min.css   2.  jquery-3.1.0.min.js  3. bootstrap.min.js

因为bootstrap所有js代码都是需要jquery做支撑的,所以只要引入bootstrap.js都必须引入jquery

 

其实博主前面都偷了个懒,没有给每个li添加a标签,在实际操作中这是非常必要的,除非你要做一个不实现跳转功能

的摆设菜单,那就随便怎么玩了。使用Bootstrap框架就必须使用a标签了,因为它的很多样式是设置在a标签上的,

不使用没有效果,相比前面的两种来说,使用框架又省力又省心,非常简单。

 

只需三步:

1.为一级菜单的ul添加class-nav nav-pills(或者nav-tabs 等等)

2.为一级菜单中有下拉二级菜单的li添加 class-dropdown

为a标签添加属性:data-toggle=”dropdown” 以及class-dropdown-toggle

3.给2步骤中li下的ul添加class-dropdown-menu

 

实例:

 

<ul class="nav nav-pills">
    <li>
        <a href="#">A</a>
    </li>
    <li class="dropdown">
        <!-- span标签 是添加一个下三角的图标 -->
        <a href="#" class="dropdown-toggle" data-toggle="dropdown">B<span class="caret"></span></a>
        <ul class="dropdown-menu">
            <li><a href="#">B1</a></li>
            <li><a href="#">B2</a></li>
            <li><a href="#">B3</a></li>
            <li><a href="#">B4</a></li>
        </ul>
    </li>
    <li><a href="#">C</a></li>
</ul>

 

 

 

 

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/132476.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PDF转换图片小工具(高清、无水印、支持随意页数)[通俗易懂]

    PDF转换图片小工具(高清、无水印、支持随意页数)[通俗易懂]疫情期间在家毕业需要,手写签名生成、成绩单的PDF文件需要加入到word中,经历了办理会员、限制5页等等的各种不方便,自己写了个小工具。平台:win764位vs15开发C#语言编写本文所编小工具,不限页数,支持高像素高清截图,随意页截取等截图如下所示:使用说明:选择起始页-终止页-像素级别(部分已默认,可以根据自己需要,一定得填写),点击按钮开始转换–选择需操作的PDF文件–选择转换完的图片的输出路径—程序提示转换成功即可。…

    2022年5月13日
    55
  • 拉姆达表达式分组_lomd表达式

    拉姆达表达式分组_lomd表达式List<Map<String,Object>>lpsgjdList=syDkKfslyxxManager.getAlpsgjdQryData(syDkKfslyxxVo); Map<Object,List<Map<String,Object>>>dongh=lpsgjdList.stream().collect( Collectors.groupingBy(e->e.get(“dongh”))); f

    2022年9月19日
    3
  • docker 常用操作命令_docker命令大全

    docker 常用操作命令_docker命令大全Docker常用命令使用1容器生命周期管理1.1dockerrun1.2dockerstart/stop/restart1.3dockerkill1.4dockerpause/unpause1.5dockerexec1.6dockerrm2容器操作2.1dockerps2.2dockerinspect2.3dockerlogs-查看docker容器日志2.4dockerexport2.5dockerport3本地镜像管理3.1dockerima

    2022年9月17日
    2
  • List集合的sublist方法

    List集合的sublist方法

    2022年2月22日
    52
  • 09年后的经典电影_2010年好看的电影有哪些

    09年后的经典电影_2010年好看的电影有哪些哈哈,这是我个人觉的09年最好看的电影,如果大家有不同的声音,请补充……01、《新娘大战》(BrideWars)  影片导演:加里.文尼克  影片主演:安妮.海瑟薇、凯特.哈德森、布莱恩.格林伯格、斯蒂夫.哈维  发行公司:20世纪福克斯  北美首映:2009年1月9日  期待指数:★★★★★★★☆☆☆7星  作品简介:  两个从…

    2022年9月30日
    4
  • Caffe2安装_caffe教程

    Caffe2安装_caffe教程一、依赖库的安装首先1.首先需要安装Ubuntu16.04与14.04都需要的依赖库。sudoaptupdatesudoaptinstall-y–no-install-recommends\build-essential\cmake\git\libgoogle-glog-dev\lib…

    2025年7月18日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号