首先看要实现的效果, 主要是关心技术实现, 所以没怎么美化

我也是初学html, 所以写的比较啰嗦

1. 使用列表将内容显示出来

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <style>
        /*写css的地方*/
    </style>
</head>
<body>
    <div id="leftMenu">
        <ul>
            <li><a href="#">一级目录1</a>
                <ul>
                    <li><a href="#">100001</a></li>
                    <li><a href="#">100002</a></li>
                </ul>
            </li>
            <li><a href="#">一级目录2</a></li>
            <li><a href="#">一级目录3</a>
                <ul>
                    <li><a href="#">300001</a></li>
                    <li><a href="#">300002</a></li>
                </ul>
            </li>
        </ul>
    </div>
</body>
</html>

这样会显示如下效果

这里不好看的地方是:

A. 二级目录预想是排在一级目录右边的, 但现在却是在下面的

B. 目录前面的小黑点和小圆圈是不需要的

2. 修改css

<style>
    *{margin: 0;padding: 0;}   /*消除各种浏览器的边距默认值*/
    #leftMenu ul{                     /*作用于id=leftMenu的元素所有含有的ul*/
        width: 100px;                 /*宽度设置为100*/
        background: #DADADA;     /*增加背景色方便查看*/
        list-style: none;           /*去除列表的小圆点*/
    }
   
    #leftMenu li{                  /*作用于id=leftMenu的元素所有含有的li*/
        width: 100px;             /*宽度设置为100*/
    }
</style>

嗯, 这样好看多了, 但是二级目录还是没有排版到一级目录的右边

3. 给ul加上 position:absolute; 使ul脱离文档流, 悬浮在原来文档流的上面

*{margin: 0;padding: 0;}   /*消除各种浏览器的边距默认值*/
    #leftMenu ul{              /*作用于id=leftMenu的元素所有含有的ul*/
        width: 100px;            /*宽度设置为100*/
        background: #DADADA;     /*增加背景色方便查看*/
        list-style: none;        /*去除列表的小圆点*/
        position:absolute;
    }
   
    #leftMenu li{              /*作用于id=leftMenu的元素所有含有的li*/
        width: 100px;            /*宽度设置为100*/
    }
</style>

4. 增加功能: 二级目录默认不显示, 鼠标悬停在一级目录上时, 才显示

<style>
    *{margin: 0;padding: 0;}   /*消除各种浏览器的边距默认值*/
    #leftMenu ul{              /*作用于id=leftMenu的元素所有含有的ul*/
        width: 100px;            /*宽度设置为100*/
        background: #DADADA;     /*增加背景色方便查看*/
        list-style: none;        /*去除列表的小圆点*/
        position:absolute;
    }
   
    #leftMenu li{              /*作用于id=leftMenu的元素所有含有的li*/
        width: 100px;            /*宽度设置为100*/
    }
    #leftMenu li>ul{       /*作用于 li的直接子元素ul */
        left: 100px;            /*一级目录本身宽度100px, 所以二级目录显示的时候要向右偏移100px, 为什么使用的是left呢? 自己学习css吧*/
        display: none;    /*二级目录默认是不显示的*/
    }
    #leftMenu li:hover>ul /*当鼠标悬停在li上时, li的直接子元素ul就显示出来*/
    {display: block;}     /*显示出来*/
</style>

5. 上面的问题是 100001 没有与 一级目录1 同一高度

<style>
    *{margin: 0;padding: 0;}   /*消除各种浏览器的边距默认值*/
    #leftMenu ul{              /*作用于id=leftMenu的元素所有含有的ul*/
        width: 100px;            /*宽度设置为100*/
        background: #DADADA;     /*增加背景色方便查看*/
        list-style: none;        /*去除列表的小圆点*/
        position:absolute;
    }
   
    #leftMenu li{              /*作用于id=leftMenu的元素所有含有的li*/
        width: 100px;            /*宽度设置为100*/
        position: relative;      /*设置为相对位置*/
    }
    #leftMenu li>ul{       /*作用于 li的直接子元素ul */
        left: 100px;            /*一级目录本身宽度100px, 所以二级目录显示的时候要向右偏移100px, 为什么要用left呢? 自己学习css吧*/
        top: 0;           /*top的偏移位置相对于父元素为0*/
        display: none;    /*二级目录默认是不显示的*/
    }
    #leftMenu li:hover>ul /*当鼠标悬停在li上时, li的直接子元素ul就显示出来*/
    {display: block;}     /*显示出来*/
</style>

6. 给一个完整界面

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <style>
        *{margin:0;padding:0;}
        #leftMenu ul{width:100px;position:absolute;background:#DADADA;list-style:none;}
        #leftMenu li{width:100px;position: relative;}
        #leftMenu li>ul{left: 100px;top: 0;display: none;}
        #leftMenu li:hover>ul{display: block;}
    </style>
</head>
<body>
    <div id="leftMenu">
        <ul>
            <li><a href="#">一级目录1</a>
                <ul>
                    <li><a href="#">100001</a></li>
                    <li><a href="#">100002</a>
                        <ul>
                            <li><a href="#">100021</a></li>
                            <li><a href="#">100022</a></li>
                        </ul>
                    </li>
                </ul>
            </li>
            <li><a href="#">一级目录2</a></li>
            <li><a href="#">一级目录3</a>
                <ul>
                    <li><a href="#">300001</a></li>
                    <li><a href="#">300002</a></li>
                </ul>
            </li>
        </ul>
    </div>
</body>
</html>

CSS实现左侧多级菜单栏的更多相关文章

  1. 左侧多级菜单,高亮显示js

    左侧多级菜单,如果本页面是当前栏目,则左侧菜单高亮显示 <ul class="nav navbar-stacked" id="navs"> {ded ...

  2. CSS浮动布局与菜单栏设计

    公司周六停电,终于可以双休了.用周五空余时间再夯实一下css基础,<CSS权威指南>概念性的内容看起来容易犯困,不如实践来得快,动手操作吧. 一.浮动布局 浮动存在问题:浮动使元素脱离文档 ...

  3. CSS布局 -- 左侧定宽,右侧自适应

    左侧定宽,右侧自适应 有很多种方法可以实现 缩小窗口试试看? 方案一: 左边左浮动,右边加个margin-left 查看 demo <!DOCTYPE html PUBLIC "-// ...

  4. css实现左侧固定宽,右侧自适应的7中方法

    一个面试会问的问题,如何实现两个盒子,左侧固定宽度,右侧自适应. 1.利用 calc 计算宽度的方法 css代码如下: .box{overflow: hidden;height: 100px;marg ...

  5. CSS 实现左侧固定,右侧自适应两栏布局的方法

    "左边固定,右边自适应的两栏布局",其中有老生常谈的float方法,BFC方法,也有CSS3的flex布局与grid布局.并非所有的布局都会在开发中使用,但是其中也会涉及一些知识点 ...

  6. HTML和CSS实现左侧固定宽度右侧内容可滚动

    在做移动端页面的时候,经常会碰到一个div中分左右两个div,左侧div固定宽度或百分比,右侧div中内容左右溢出,需要左右滑动才可以浏览到全部内容,为此写了一个demo. 处理这个问题的核心关键点是 ...

  7. [转]css实现左侧宽度自适应,右侧固定宽度

    原文地址:https://segmentfault.com/a/1190000008411418 页面布局中经常用会遇到左侧宽度自适应,右侧固定宽度,或者左侧宽度固定,右侧自适应.总之就是一边固定宽度 ...

  8. css中左侧固定,右侧自适应

    谈谈我开始出来工作时候的一道面试题吧 当初我记得在太平洋网络面试的时候,面试官给我出了这么一道题: 有一个外层的div 中间有左右两个div 要求左侧的div 1.只告诉你宽度;       2.只告 ...

  9. layui 左侧三级菜单栏

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

随机推荐

  1. Linux(Centos7)下搭建SVN服务器

    操作系统: CentOS 7.6 64位 第一步:通过yum命令安装svnserve,命令如下: 检测svn是否安装: rpm -qa subversion #检查现有版本,如果输入命令后没有提示的话 ...

  2. java fail-fast和fail-safe

    快速失败(fail—fast) 在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(如增加.删除等),则会抛出Concurrent Modification Exception. ...

  3. 游戏数据分析中“次日留存率”与“游戏生命周期第N天上线率”的SAS实现

    在游戏行业,次日留存率是个很重要的指标,对于评价一款游戏的优劣具有很重要的参考价值. 下面先看以下相关的定义: 用户留存:统计时间区间内,新登用户在随后不同时期的登录使用情况. 日次留存率:日新登用户 ...

  4. gradle重复依赖终极方案解决办法

    buildscript { repositories { google() jcenter() } dependencies { classpath 'com.android.tools.build: ...

  5. Vue--生命周期函数

    生命周期函数就是组件挂载.以及组件销毁的时候触发的一系列方法,这些方法叫做生命周期函数: beforeCreate(){ console.log('实例创建之前-1') }, created(){ c ...

  6. C语言中的作用域,链接属性和存储类型

    作用域 当变量在程序的某个部分被声明的时候,他只有在程序的一定渔区才能被访问,编译器可以确认4种不同类型的作用域:文件作用域,函数作用域,代码块作用域和原型作用域 1.代码块作用域:位于一对花括号之间 ...

  7. 爬取WX小程序的数据

    方法一: 使用TBS工具,调试跟踪获取URL https://x5.tencent.com/tbs/guide/debug/download.html https://x5.tencent.com/t ...

  8. [Unity优化]UI优化(三):GraphicRebuild

    参考链接: https://blog.csdn.net/jingangxin666/article/details/80143176 调试过程: 1.修改Image的颜色 2.Graphic.SetV ...

  9. Python cx_Oracle 安装小记

    因为我的个人网站 restran.net 已经启用,博客园的内容已经不再更新.请访问我的个人网站获取这篇文章的最新内容,Python cx_Oracle 安装小记 SQLAlchemy 是 Pytho ...

  10. 星级评分原理 N次重写的分析

    使用的是雪碧图,用的软件是CSS Sprite Tools 第一次实现与分析: <!DOCTYPE html> <html> <head> <meta cha ...