响应式导航栏不会做?看我一分钟学会制作导航栏!

引言

       随着互联网技术的飞速发展,用户体验在网页设计中的重要性日益凸显。其中,导航栏作为网页的“指南针”,不仅能帮助用户快速定位所需内容,还能体现网站的整体风格和设计理念。本文将介绍如何使用HTML、CSS和JavaScript制作一个响应式导航栏,以适应不同屏幕尺寸,并提供优雅的用户体验。

一、导航栏的HTML结构

       首先,我们需要构建导航栏的HTML骨架。这个导航栏包括一个Logo、一个菜单图标(用于在小屏幕上展开导航栏)、导航链接、搜索框和登录注册按钮。

创建一个名为 index.html的页面文件

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>导航栏</title><link rel="stylesheet" href="styles.css">
</head><body><div class="navbar" id="nav"><div class="logo">saycode.cn</div><div class="menu-icon" id="menuIcon"><span></span><span></span><span></span><span></span></div><ul id="navbarMenu"><li><a href="#">首页</a></li><li><a href="#">我的教程</a></li><li><a href="#">我的创意</a></li><div class="search-box"><input type="text" placeholder="Search..."></div><div class="buttons"><button class="login">登录</button><button class="register">注册</button></div></ul></div><script src="script.js"></script>
</body></html>

二、导航栏的CSS样式

       接下来,我们使用CSS为导航栏添加样式。通过设置display: flex;,我们可以轻松实现导航栏元素的水平排列。同时,我们为不同元素定义了不同的样式,如Logo的字体大小和颜色、导航链接的悬停效果等。

创建一个名为 styles.css 样式文件

* {box-sizing: border-box;
}body {margin: 0;padding: 0;font-family: Arial, sans-serif;background-color: #ffe7df;
}.navbar {background-color: #ffffff;color: #fff;padding: 10px 40px;display: flex;align-items: center;justify-content: space-between;
}.logo {font-size: 24px;font-weight: bold;color: #232c53;
}.navbar ul {list-style-type: none;margin: 0;padding: 0;display: flex;align-items: center;
}.navbar li {position: relative;margin-right: 15px;
}.navbar li a {color: #777b91;text-decoration: none;padding: 10px;
}.navbar li a:hover {color: #141e46;
}.search-box {position: relative;
}.search-box input {width: 200px;height: 30px;border: none;padding: 5px 10px;border-radius: 6px;background-color: #eff6f8;
}.buttons {display: flex;
}.buttons button {margin-left: 10px;padding: 5px 10px;border: none;cursor: pointer;
}.login {color: #232c53;background-color: #fff;
}.register {color: #fff;background-color: #232c53;border-radius: 10px;
}

三、响应式设计

       为了使导航栏在不同屏幕上都能良好地显示,我们使用了媒体查询(Media Query)。当屏幕宽度小于768px时,我们将隐藏导航链接、搜索框和按钮,并显示一个菜单图标。当用户点击该图标时,导航栏将展开显示所有元素。

/* 添加响应式设计的样式 */
@media screen and (max-width: 768px) {.navbar {position: relative;padding: 10px 10px;}/* 在小屏幕上隐藏导航栏和搜索框等 */.navbar ul,.search-box,.buttons {display: none;}/* 显示汉堡式图标 */.navbar .menu-icon {display: block;position: relative;width: 30px;height: 20px;cursor: pointer;}.navbar .menu-icon span {display: block;position: absolute;height: 4px;width: 100%;background: #232c53;border-radius: 4px;opacity: 1;left: 0;transform: rotate(0deg);transition: 0.25s ease-in-out;}.navbar .menu-icon span:nth-child(1) {top: 0px;}.navbar .menu-icon span:nth-child(2),.navbar .menu-icon span:nth-child(3) {top: 10px;}.navbar .menu-icon span:nth-child(4) {top: 20px;}/* 菜单展开时的样式 */.navbar.open .menu-icon span:nth-child(1) {top: 18px;width: 0%;left: 50%;}.navbar.open .menu-icon span:nth-child(2) {transform: rotate(45deg);}.navbar.open .menu-icon span:nth-child(3) {transform: rotate(-45deg);}.navbar.open .menu-icon span:nth-child(4) {top: 18px;width: 0%;left: 50%;}/* 展开菜单时的导航栏样式 */.navbar.open ul {display: flex;flex-direction: column;}.navbar.open .search-box,.navbar.open .buttons {display: block;}.search-box,.buttons {display: block;}#navbarMenu {width: 100%;flex-direction: column;gap: 10px;padding: 10px 0;background-color: #ffffff;border-radius: 10px;position: absolute;left: 0;bottom: -200px;text-align: center;}#navbarMenu li a {font-size: 20px;}
}

四、JavaScript交互

最后,我们使用JavaScript为菜单图标添加点击事件。当用户点击图标时,我们将为导航栏添加一个open类,以改变其样式并显示隐藏的元素。

创建一个名为 script.js 文件

document.getElementById('menuIcon').addEventListener('click', function () {  var navbar = document.getElementById('nav');  navbar.classList.toggle('open');  
});

五、效果展示

 查看小红薯更多精彩内容  查看小红薯更多精彩内容

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/814896.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot 微服务token 传递实现

1、前言 随着微服务的流行&#xff0c;微服务之间的安全以及业务需要&#xff0c;都需要穿递token &#xff0c;而token的传递一般通过header 头来传递。从架构的角度来讲 &#xff0c;一般的企业应用都由nginx、业务网关和各个微服务组成。这个nginx 传递header 我就不讲述。下…

[附带黑子定制款鸽鸽版素材包]更改文件夹图标,更改系统音效,更改鼠标指针及样式。

更改文件夹图标 1.选择图片在线格式转换网站转换为ico格式 2.右键文件夹选择属性 3.点击自定义&#xff0c;点击更改图标超链接 4.点击预览选择生成的ico文件 5.点击打开&#xff0c;点击确定&#xff0c;点击应用 更改系统音效&#xff08;真爱粉强烈推荐&#xff09; 1…

react query 学习笔记

文章目录 react query 学习笔记查询客户端 QueryClient获取查询客户端 useQueryClient异步重新请求数据 queryClient.fetchQuery /使查询失效 queryClient.invalidateQueries 与 重新请求数据queryClient.refetchQueries 查询 QueriesuseQuery查询配置对象查询的键值 Query Key…

老板最怕你出这样的代码。。。

大家好&#xff0c; 这一个月时间&#xff0c;阿里巴巴、滴滴、腾讯都发生过应用线上故障的事情&#xff0c;很多同学说是降本增“笑”的后果然后圈内流传一个新想法&#xff0c;为了避免“开源节流” 的事情&#xff0c;工作中要写一些防御性的代码。 什么意思&#xff1f;就…

现代电商会员管理新玩法——付费会员

现在&#xff0c;无论是线上还是线下&#xff0c;几乎都在做会员管理。会员规则五花八门&#xff0c;不仅有常见的注册会员&#xff0c;还出现了付费会员。付费会员机制&#xff0c;从成为会员的第一步就开始筛选&#xff0c;选出粘性高、要求高、复购高且有一定消费力的用户群…

JVM、maven、Nexus

一、jvm简介 1.应用程序申请内存时出现的三种情况&#xff1a; ①OOM:内存溢出&#xff0c;是指应用系统中存在无法回收的内存或使用的内存过多&#xff0c;最终使得程序运行要用到的内存大于能提供的最大内存。此时程序就运行不了&#xff0c;系统会提示内存溢出&#xff0c…

网络篇11 | 网络层 ICMP

网络篇11 | 网络层 ICMP 01 简介02 报文格式1&#xff09;Type(类型)2&#xff09;Code(代码)3&#xff09;Checksum(校验和)4&#xff09;ICMP数据部分 03 ICMP数据抓包1&#xff09;类型 8&#xff1a;回显请求&#xff08;Echo Request&#xff09;2&#xff09;类型 13&…

[Java、Android面试]_18_详解Handler机制 常见handler面试题(非常重要,非常高频!!)

本人今年参加了很多面试&#xff0c;也有幸拿到了一些大厂的offer&#xff0c;整理了众多面试资料&#xff0c;后续还会分享众多面试资料。 整理成了面试系列&#xff0c;由于时间有限&#xff0c;每天整理一点&#xff0c;后续会陆续分享出来&#xff0c;感兴趣的朋友可关注收…

【智能优化算法】人工原生动物优化器(APO)

人工原生动物优化器(Artificial Protozoa Optimizer&#xff0c;APO)是发表在中科院一区期刊‘Knowledge-Based Systems’期刊上“Artificial Protozoa Optimizer (APO): A novel bio-inspired metaheuristic algorithm for engineering optimization”这篇文章上的算法。 01.引…

下载好了annaconda,但是在创建一个新的Conda虚拟环境报错

文章目录 问题描述&#xff1a;解决方案1.生成一个配置文件 问题总结 问题描述&#xff1a; ProxyError(MaxRetryError(“HTTPSConnectionPool(host‘repo.anaconda.com’, port443): Max retries exceeded with url: /pkgs/pro/win-64/repodata.json.bz2 (Caused by ProxyErr…

基于深度学习的智能停车场车牌识别计费系统(完整程序+训练数据集+开题报告+论文))

摘要 本篇论文研究的是基于车牌识别技术的智能停车场管理系统&#xff0c;采用基于深度学习的车牌识别算法&#xff0c;通过卷积神经网络对车牌图像进行处理和分析&#xff0c;实现车牌字符的识别和车牌信息的提取。同时&#xff0c;本文还设计了一个智能停车场管理系统&#x…

2024最新版守约者二级域名分发系统

主要功能 二级域名管理&#xff1a;我们的系统提供全面的二级域名管理服务&#xff0c;让您轻松管理和配置二级域名。 域名分发&#xff1a;利用我们先进的域名分发技术&#xff0c;您可以自动化地分配和管理域名&#xff0c;确保每个用户或客户都能及时获得所需的域名资源。 自…

前端开发攻略---Vue实现防篡改水印的效果。删除元素无效!更改元素属性无效!支持图片、元素、视频等等。

1、演示 2、水印的目的 版权保护&#xff1a;水印可以在图片、文档或视频中嵌入作者、品牌或版权所有者的信息&#xff0c;以防止未经授权的复制、传播或使用。当其他人使用带有水印的内容时&#xff0c;可以追溯到原始作者或版权所有者&#xff0c;从而加强版权保护。 身份识…

流程图步骤条

1.结构 <ul class"stepUl"> <li class"stepLi" v-for"(item, index) in stepList" :key"index"> <div class"top"> <p :class"{active: currentState > item.key}">{{ item.value }}…

Gradle 实战 - 启动main函数-ApiHug准备-工具篇-012

&#x1f917; ApiHug {Postman|Swagger|Api...} 快↑ 准√ 省↓ GitHub - apihug/apihug.com: All abou the Apihug apihug.com: 有爱&#xff0c;有温度&#xff0c;有质量&#xff0c;有信任ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace ApiHug …

【ELK】ELK企业级日志分析系统

搜集日志&#xff1b;日志处理器&#xff1b;索引平台&#xff1b;提供视图化界面&#xff1b;客户端登录 日志收集者&#xff1a;负责监控微服务的日志&#xff0c;并记录 日志存储者&#xff1a;接收日志&#xff0c;写入 日志harbor&#xff1a;负责去连接多个日志收集者&am…

PCL 高斯滤波(C++详细过程版)

目录 一、概述二、代码实现三、结果展示1、滤波前2、滤波后3、对比PCL 高斯滤波(C++详细过程版)由CSDN点云侠原创,爬虫自重。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、概述 高斯滤波在PCL里有现成的调用函数,具体算法原理和实现代码见:

2路音频解码器JR-AD201

音频解码器 详细介绍 JR-AD201 2路音频解码器&#xff0c;支持RF/ASI/IP输入&#xff0c;支持DRA/AC3/EAC3/AAC/MPEG等音频&#xff0c;输出&#xff1a;2路模拟立体声&#xff0c;2路AES/EBU。 产品特点 支持多种输入方式RF/IP/ASI 接口丰富&#xff0c;AES/EBU/模拟立体声/A…

CSS盒模型(详讲)

目录 概述&#xff1a; 内容区&#xff08;content&#xff09;&#xff1a; 内边距&#xff08;paddingj&#xff09;&#xff1a; 前言&#xff1a; 设置内边距&#xff1a; 边框&#xff08;border&#xff09;&#xff1a; 前言&#xff1a; 示例&#xff1a; 外边…

Android开发——布局

LinearLayout RelativeLayout 所谓父子容器&#xff0c;就是嵌套容器时存在的关系。 根据兄弟容器定位需要传入兄弟的id。 通用属性 FrameLayout (覆盖布局&#xff09; TableLayout (表格&#xff09; GridLayout (网格) 子控件属性