【web】一个自适应的导航栏前端设计(只含HTML+CSS)

简介: 【web】一个自适应的导航栏前端设计(只含HTML+CSS)

本文是基于上一篇文章的补充。

效果如下


q1.png

q2.png

q3.png

HTML源码


点击查看HTML代码

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>资源分享站 - 软件 网站 书籍文档 学习资料</title>
    <link href="css/index.css" rel="stylesheet" type="text/css">
</head>
<body>
    <header>
        <div class="box-logo">
            <a href="#" alt="资源分享站" class="logo">
                <div class="img-logo-box img-logo"
                    style="background: url(images/LOGO.png) no-repeat;background-size: 100% auto;">
                </div>
                <div class="img-logo-box text-logo">
                    萌狼工作室
                </div>
            </a>
            <nav>
                <ul>
                    <li><a href="#">资源</a></li>
                    <li><a href="#">首页</a></li>
                    <li><a href="#">网站</a></li>
                    <li><a href="#">关于</a></li>
                </ul>
            </nav>
            <div class="header-info">
                <a href=""><img src="images/search.svg" alt="搜索"/></a>
                <a href=""><img src="images/msg.svg" alt="消息"/></a>
                <a href=""><img src="images/moon.svg" alt="夜间模式"/></a>
                <a href="" class="sm-show"><img src="images/menu.svg" alt="夜间模式"/></a>
                <div class="btn-login">
                    <a>登录</a>
                </div>
            </div>
        </div>
    </header>
</body>
</html>

CSS源码

点击查看CSS代码

:root{
--font-main-color:black;
--font-hover-color:red;
--font-btn-color:snow;
--background-btn-color:red;
--background-color:snow;
--shadow-color:rgba(0,0,0,0.1);
}
*{
    margin: 0;
    padding: 0;
}
/*标签控制*/
a{
    text-decoration: none;
}
li{
    list-style: none;
}
/*标签控制结束*/
/*头部<header>开始*/
header{
    margin: 0;
    padding: 0;
    width:100%;
}
header .box-logo{
    width: 100%;
    display: flex;
    /*背景颜色*/
    background-color: var(--background-color);
    /*阴影*/
    box-shadow: 1px 1px 1px 1px var(--shadow-color);
}
header .logo{
    margin: 0;
    padding:0.25em 1em;
    height: 100%;
    font-size: 1.5em;
    /*设置字体颜色*/
    color:var(--font-main-color);
}
header .logo .img-logo-box{
    /*LOGO和文字在一行*/
    display: inline-block;
    /*LOGO和文字上下居中,实现对齐*/
    vertical-align:middle;
}
header nav{
    /*为了让它右边的元素靠右*/
    flex: 1;
    padding-left: 1em;
    /*因为父元素是flex,所以使用margin:auto可以实现内容垂直居中*/
    margin: auto;
    font-size: 1.3em;
}
header nav ul{
    display: block;
    margin: auto;
    vertical-align: middle;
}
header nav ul li{
    margin: auto 0.25em;
    /*让li标签横向排列*/
    display: inline-block;
}
header nav ul li a{
    /*设置字体颜色*/
    color:var(--font-main-color);
}
header nav ul li:hover a{
    color:var(--font-hover-color);
    text-decoration: var(--font-main-color) 1px;
}
header .header-info{
    display: contents;
    margin: auto;
    padding-right: 1.5em;
}
header .header-info a{
    margin: auto 0.5em;
}
header .header-info .btn-login{
    margin: auto 1em;
    /*因为父元素设置了display:contents,所以这里就用设置display:inline-block;*/
    /*display: inline-block;*/
    color:var(--font-btn-color);
    background-color: var(--background-btn-color);
    border-radius: 5px;
}
/*默认*/
@media (min-width: 767px){
    header .logo .img-logo{
        height: 1.5em;
        width: 1.5em;
    }
    header .logo .text-logo{
        font-size: 1.3em;
    }
    header .header-info .sm-show
    {
        display: none;
    }
    header .header-info a img{
        width: 1.5em;
    }
    header .header-info .btn-login a{
        font-size: 1.25em;
    }
}
/* 横向放置的手机和竖向放置的平板之间的分辨率 */
@media (max-width: 767px) {
    header .logo{
        /*nav不显示时,靠logo将最右边的元素挤到最右*/
        flex:1;
    }
    header .logo .img-logo{
        height: 1.2em;
        width: 1.2em;
    }
    header .logo .text-logo{
        font-size: 1em;
    }
    header nav{
        display: none;
    }
    header .header-info a img{
        width: 1.2em;
    }
    header .header-info .btn-login a{
        font-size: 1em;
    }
}
/* 横向放置的手机及分辨率更小的设备 */
@media (max-width: 480px) {
    header .logo{
        /*nav不显示时,靠logo将最右边的元素挤到最右*/
        flex:1;
    }
    header .logo .img-logo{
        height: 1em;
        width: 1em;
    }
    header .logo .text-logo{
        font-size: 0.8em;
        display: none;
    }
    header nav{
        display: none;
    }
    header nav{
        display: none;
    }
    header .header-info a img{
        width: 1em;
    }
    header .header-info .btn-login a{
        font-size: 1em;
    }
}
/*CSS 折叠 复制 全屏


相关文章
|
22天前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
37 3
|
18天前
|
移动开发 前端开发 JavaScript
[HTML、CSS]细节与使用经验
本文总结了前端开发中的一些重要细节和技巧,包括CSS选择器、定位、层级、全局属性、滚轮控制、轮播等。作者以纯文字形式记录,便于读者使用<kbd>Ctrl + F</kbd>快速查找相关内容。文章还提供了示例代码,帮助读者更好地理解和应用这些知识点。
40 1
[HTML、CSS]细节与使用经验
|
19天前
|
移动开发 前端开发 JavaScript
[HTML、CSS]知识点
本文涵盖前端知识点扩展、HTML标签(如video、input、canvas)、datalist和details标签的使用方法,以及CSS布局技巧(如margin、overflow: hidden和动态height)。文章旨在分享作者的学习经验和实用技巧。
30 1
[HTML、CSS]知识点
|
14天前
|
移动开发 JavaScript 前端开发
html table+css实现可编辑表格的示例代码
html table+css实现可编辑表格的示例代码
|
8天前
|
消息中间件 前端开发 JavaScript
探索微前端架构:构建现代Web应用的新策略
本文探讨了微前端架构的概念、优势及实施策略,旨在解决传统单体应用难以快速迭代和团队协作的问题。微前端允许不同团队独立开发、部署应用的各部分,提升灵活性与可维护性。文中还讨论了技术栈灵活性、独立部署、团队自治等优势,并提出了定义清晰接口、使用Web组件、状态管理和样式隔离等实施策略。
|
10天前
|
前端开发 JavaScript
用HTML CSS JS打造企业级官网 —— 源码直接可用
必看!用HTML+CSS+JS打造企业级官网-源码直接可用,文章代码仅用于学习,禁止用于商业
51 1
|
15天前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
28 3
|
19天前
|
监控 前端开发 JavaScript
探索微前端架构:构建可扩展的现代Web应用
【10月更文挑战第29天】本文探讨了微前端架构的核心概念、优势及实施策略,通过将大型前端应用拆分为多个独立的微应用,提高开发效率、增强可维护性,并支持灵活的技术选型。实际案例包括Spotify和Zalando的成功应用。
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
112 3
下一篇
无影云桌面