最新CSS3纵向菜单的实现

纵向菜单

通过下面例子,你会知道把列表转换成菜单的关键技术

a中的#是URL的占位符可以点击,真正用途中写实际URL

html 复制代码
<nav class="list1">
    <ul>
        <li><a href="#">Alternative</a></li>
        <li><a href="#">Country</a></li>
        <li><a href="#">Jazz</a></li>
        <li><a href="#">Rock</a></li>
    </ul>
</nav>
  1. 新建HTML页面,并初始化上面的内容
  2. 去掉默认的内边距和外边距
  3. 设置菜单位置外边框50px,宽度150px
  4. 给菜单加上边框1px,固态,#f00,圆角3px,内边距上5px,左右10px,下3px
  5. 去掉项目符号并添加链接间距上下3px,左右10px
  6. 非首位选择器设置上边框1px,实线,#f00
  7. 链接添加样式,去掉下划线,字体大小20px,字体为Exo, helvetica,arial, sans-serif,字体粗细400,字体颜色#000,背景颜色#ffed53
  8. 悬停到a上高亮,字体变为#069
  9. 目前只有文本可以点击(a是行内元素收缩包住了文本),为了用户体验整行都能点击,将li的内边距移到a内部,上边框红线给非首位li中的a加上,a为了撑满显示为块级元素。

案例源码如下:

html 复制代码
<!DOCTYPE html>
<html>
    <head>
    <meta charset="utf-8">
    <title></title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        nav {
            margin: 50px;
            width: 150px;
        }
        .list1 ul {
            border: 1px solid #f00;
            border-radius: 3px;
            padding: 5px 10px 3px;
        }
        .list1 li {
            list-style-type: none;
        }
        .list1 li+li a {
            border-top: 1px solid #f00;
        }
        
        .list1 a {
            display: block;
            padding: 3px 10px;
            text-decoration: none;
            font: 20px Exo, helvetica, arial, sans-serif;
            font-weight: 400;
            color: #000;
            background: #ffed53;
        }
        .list1 a:hover {
            color: #069;        
        }
    </style>
    </head>
    <body>
    <nav class="list1">
        <ul>
            <li><a href="#">Alternative</a></li>
            <li><a href="#">Country</a></li>
            <li><a href="#">Jazz</a></li>
            <li><a href="#">Rock</a></li>
        </ul>
    </nav>
    </body>
</html>
相关推荐
涔溪11 小时前
如何解决微前端架构中主应用和微应用的通信问题?
前端·架构
重铸码农荣光11 小时前
深入理解 JavaScript 原型链:从 Promise.all 到动态原型的实战探索
前端·javascript·promise
进击的野人11 小时前
深入理解 Async/Await:现代 JavaScript 异步编程的优雅解决方案
javascript·面试·ecmascript 6
我叫黑大帅11 小时前
什么叫可迭代对象?为什么要用它?
前端·后端·python
颜渊呐11 小时前
Vue3 + Less 实现动态圆角 TabBar:从代码到优化实践
前端·css
PineappleCoder11 小时前
pnpm 凭啥吊打 npm/Yarn?前端包管理的 “硬链接魔法”,破解三大痛点
前端·javascript·前端工程化
fruge11 小时前
前端文档自动化:用 VitePress 搭建团队技术文档(含自动部署)
运维·前端·自动化
CoolerWu12 小时前
TRAE SOLO实战成功展示&总结:一个所见即所得的笔记软体
前端·javascript
Cassie燁12 小时前
el-button源码解读1——为什么组件最外层套的是Vue内置组件Component
前端·vue.js
vx_bscxy32212 小时前
告别毕设焦虑!Python 爬虫 + Java 系统 + 数据大屏,含详细开发文档 基于web的图书管理系统74010 (上万套实战教程,赠送源码)
java·前端·课程设计