基于HTML5和CSS3搭建一个Web网页(二)

倘若代码中有任何问题或疑问,欢迎留言交流~

网页描述

创建一个包含导航栏、主内容区域和页脚的响应式网页。
需求:

  1. 导航栏:
    在页面顶部创建一个导航栏,包含首页、关于我们、服务和联系我们等链接。
    设置导航栏样式,包括字体、颜色和背景颜色等。
    在滚动页面时,导航栏应始终固定在顶部。
  2. 主内容区域:
    包含介绍性文本和至少两张图片。
    对文本和图片应用样式,例如字体样式、对齐方式等。
  3. 页脚:
    包含版权信息和日期,并进行相应的样式设计.
  4. 响应式布局:
    当在不同大小的设备(如手机、平板电脑、笔记本电脑等)上查看时,网页应该具有很好的可读性和易用性。
    提示:
    使用HTML5的新元素,如header、footer、nav、section、article等进行布局。
    使用CSS3的新特性,如渐变、阴影、动画、Flexbox或Grid布局等提升网页的视觉效果。
    使用媒体查询(@media)来设置响应式布局的断点。

在上一篇文字已经解决了导航栏的基本部分,基于HTML5和CSS3搭建一个Web网页(一)。下面继续完成这个网页的开发。

项目结构

基于上一篇得基础,我将导航栏的布局改变了一下,因为发现导航栏只有四个选项,四等分好像有点难看。所以让它们更紧凑了一点,并且改变了一下项目结构。
根据项目要求,可以看到网页分为三个部分
分别是导航栏、主体内容和页脚
因此html主题结构为三个div标签。代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Web</title>
    <link rel="stylesheet" href="../css/style.css">
    <link rel="stylesheet" href="../css/header.css">
    <link rel="stylesheet" href="../css/main.css">
    <link rel="stylesheet" href="../css/footer.css">
</head>
<body>
    <div class="header"></div>
    <div class="main"></div>
    <div class="footer"></div>
</body>
</html>

项目文件夹结构如图所示:
在这里插入图片描述

  1. style.css为主体css样式
  2. header.css、main.css和footer.css依次为导航栏、主体内容和页脚样式

style.css

/* 去除所有元素默认的margin、padding和border值 */
* {
    margin: 0;
    padding: 0;
    border: 0;
}

/* 初始化html、body宽高100%,占满整个窗口 */
html, body {
    height: 100%;
    width: 100%;
}

/* 设置一个类来清除浮动 */
.clearfix {
    clear: both;
}

这个清除浮动类比较重要,在后边的代码过程中会经常用到。

导航栏的响应式布局

响应式布局里,我们将情况分为五种:

  1. 在屏幕宽度最大为575px(通常是手机设备)
  2. 当屏幕宽度在576px到767px(通常是平板设备)
  3. 当屏幕宽度在768px到991px(通常是小型电脑设备)
  4. 当屏幕宽度在992px到1199px(通常是中型电脑设备)
  5. 当屏幕宽度在1200px以上(通常是大屏电脑设备)
    并且在css文件夹中建立media.css文件,用来存放编写网页的响应式效果。
    基于这五个情况,可以列出media.css文件的框架如下:
/* 超小屏幕(小于等于575px) */
@media (max-width: 575px) {

}
/* 小屏幕 */
@media (min-width: 576px) {

}
/* 中等屏幕 */
@media (min-width: 768px) {
    
}
/* 大屏幕 */
@media (min-width: 992px) {
    
}
/* 超大屏幕 */
@media (min-width: 1200px) {
    
}

导航栏的响应式布局思路

导航栏的响应式布局思路为,小屏幕时为了观感,用汉堡菜单按钮来代替导航栏的选项。
汉堡菜单在我之前的文章有提过:超小屏幕下的导航栏-汉堡菜单按钮效果。
即实现下图中的效果,而其余屏幕则改变导航栏的大小即可。
在这里插入图片描述

index.html

那么index.html文件为

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Web</title>
    <link rel="stylesheet" href="../css/style.css">
    <link rel="stylesheet" href="../css/header.css">
    <link rel="stylesheet" href="../css/main.css">
    <link rel="stylesheet" href="../css/footer.css">
    <link rel="stylesheet" href="../css/media.css">
</head>
<body>
    <div class="header">
        <div class="header-main">
            <!-- 借助复选框实现菜单效果 -->
            <input type="checkbox" id="toggle-box"> 
            <!-- 汉堡菜单按钮 -->
            <label for="toggle-box" class="menu"></label>
            <ul>
                <li><a href="index.html">  首页  </a></li>
                <li><a href="#">关于我们</a></li>
                <li><a href="#">  服务  </a></li>
                <li><a href="#">联系我们</a></li>
            </ul>
        </div>
        <!-- 清除浮动类 -->
        <div class="clearfix"></div>
    </div>
    <div class="main"></div>
    <div class="footer"></div>
</body>
</html>

header.css

对应header.css文件为:

.header {
    /* 设置导航栏的大小和颜色 */
    width: 100%;
    background-color: rgba(0,0,0,0.4);

    /* 固定导航栏 */
    position: fixed;
}
.header-main {
    width: 70%;
}
.header .header-main ul {
    /* Flex需要初始化ul标签的宽度 */
    width: 100%;

    /* 导航栏采用Flex布局方式 */
    /* 采用Flex布局的好处:1.使得代码更加简洁 2.不用考虑宽的设置,会自动占满 */
    display: flex;

    /* 去掉列表点 */
    list-style: none;
}
.header .header-main ul  li {
     /* 设置 flex-grow 为 1 保证所有的 li 元素都有相等的宽度,而不论其内容的宽度 */
     flex-grow: 1;
     height: 100%;
     /* 对齐文本到中心 */
     text-align: center;
}
ul li a {
    /* 设置字体大小和颜色,并去掉下划线 */
    font-size: 18px;
    color: black;
    text-decoration: none;

    display: block;
    margin-top: 12px;
    height: 36px;
    border-bottom: 2px rgba(0,0,0,0.4);
}

ul li a:hover {
    color: white;
    height: 34px;
    border-bottom: 2px solid white;
} 
/* 默认情况下隐藏汉堡菜单按钮 */
#toggle-box, .menu {
    display: none;
}

media.css文件

/* 超小屏幕(小于等于575px) */
@media (max-width: 575px) {
    .header-main {
        width: 94%;
        margin-left: 3%;
        margin-right: 3%;
        /* 美观 */
        min-height: 35px;
        line-height: 35px;
    }
    .header .header-main ul {
        display: none;
    }
    .header-main ul li {
        display: block;
        width: 100%;
        text-align: center;

    }
    .header-main .menu {
        display: block;
        text-align: center;

    }
    #toggle-box:checked~ul {
        display: block;
    }
}
/* 小屏幕 */
@media (min-width: 576px) {
    .header-main {
        width: 80%;
        margin-left: 10%;
        margin-right: 10%;
    }
}

/* 中等屏幕 */
@media (min-width: 768px) {
    .header-main {
        width: 70%;
        margin-left: 15%;
        margin-right: 15%;
    }
}

/* 大屏幕 */
@media (min-width: 992px) {
    .header-main {
        width: 60%;
        margin-left: 20%;
        margin-right: 20%;
    }
}

/* 超大屏幕 */
@media (min-width: 1200px) {
    .header-main {
        width: 50%;
        margin-left: 25%;
        margin-right: 25%;
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

什么是预训练模型

如果你要做一个计算机视觉的应用&#xff0c;相比于从头训练权重&#xff0c;或者说从随机初始化权重开始&#xff0c;如果你下载别人已经训练好网络结构的权重&#xff0c;通常能够进展得相当快&#xff0c;可以用这个作为预训练模型&#xff0c;然后转换到你感兴趣的任务上。…

Linux虚拟主机中如何创建文件和文件夹

我想创建一个新的文件夹&#xff0c;由于我使用的Hostease的Linux虚拟主机产品默认带普通用户权限的cPanel面板&#xff0c;但是不知道如何在cPanel上操作创建文件&#xff0c;因为也是对于Hostease主机产品不是很了解&#xff0c;因此联系Hostease的咨询了Hostease技术支持&am…

汽车R155法规中,汽车获取到的VTA证书,E后面的数字表示什么意思?

标签&#xff1a; 汽车R155法规中&#xff0c;汽车获取到的VTA证书&#xff0c;E后面的数字表示什么意思&#xff1f;&#xff1b; 汽车&#xff1b;VTA认证; 有些厂商汽车拿到的VTA证书上面写着E9&#xff0c; 有些厂商汽车拿到的VTA证书上面写着E5&#xff0c;E9与E5有什么差…

微信小程序-常用的视图容器类组件

一.组件分类 小程序中的组件也是由宿主环境提供的&#xff0c;开发者可以基于组件快速搭建出漂亮的页面结构。 官方把小程序的组件分为了9大类: (1) 视图容器 (2) 基础内容 (3) 表单组件 (4)导航组件 (5) 媒体组件 (6) map 地图组件 (7) canvas 画布组件 (8) 开放能力 (9) 无…

【小程序 按钮 表单 】

按钮 代码演示 xxx.wxml <view class"boss" hover-class"box"hover-start-time"2000"hover-stay-time"5000">测试文本<view hover-stop-propagation"true">子集</view><view>子集2</view>…

网络实时安全:构筑数字时代的铜墙铁壁

什么是网络实时安全&#xff1f; 网络实时安全&#xff0c;简而言之&#xff0c;是一种能够在威胁发生的瞬间即刻识别、响应并有效抵御的安全机制。它强调的是速度与效率&#xff0c;确保网络环境能够持续处于安全状态。这背后&#xff0c;离不开高科技的支撑——扩展检测系统…

【openlayers系统学习】3.1-3.2彩色GeoTIFF图像渲染

一、彩色GeoTIFF图像渲染 Sentinel-2 卫星任务收集并传播覆盖地球陆地表面的图像&#xff0c;重访频率为 2 至 5 天。传感器收集多波段图像&#xff0c;其中每个波段都是电磁频谱的一部分。 2A 级 (L2A) 产品提供以下频段的表面反射率测量&#xff1a; BandDescriptionCentra…

Python vscode debug: Error while enumerating installed packages.解决

记录一个vscode python debug时出现的错误&#xff1a; 具体错误如下&#xff1a; E00000.030: Error while enumerating installed packages. Traceback (most recent call last): File “/root/.vscode-server/extensions/ms-python.debugpy-2024.0.0-linux-x64/bundled/lib…

如何在华为手机上恢复已删除的视频[4种解决方案]

概括 在数字媒体时代&#xff0c;智能手机已成为我们的个人金库&#xff0c;存储以视频形式捕捉的珍贵记忆。然而&#xff0c;意外删除这些珍贵的文件可能会是一次令人心痛的经历。对于华为手机用户来说&#xff0c;由于删除或其他意外导致视频丢失尤其令人痛苦。但不用担心&a…

Linux驱动学习之模块化,参数传递,符号导出

1.模块化 1.1.模块化的基本概念&#xff1a; 模块化是指将特定的功能或组件独立出来&#xff0c;以便于开发、测试和维护。在Linux设备驱动中&#xff0c;模块化允许将驱动程序作为内核模块动态加载到系统中&#xff0c;从而提高了系统的灵活性和可扩展性。 1.2.Linux内核模…

解决win系统msvcp140.dll丢失的多种常用方法,亲测有效!

msvcp140.dll 是一个重要的Windows系统文件&#xff0c;属于Microsoft Visual C Redistributable runtime components的一部分&#xff0c;特别与Visual Studio 2015及之后版本编译的C应用程序相关联。这个动态链接库&#xff08;DLL&#xff09;文件包含了一系列C标准库的功能…

从参数变化解读 MySQL 8.2.0 发版说明

↑ 关注“少安事务所”公众号&#xff0c;欢迎⭐收藏&#xff0c;不错过精彩内容~ 日前&#xff0c;MySQL 8.2.0 创新版本已正式上线&#xff0c;并提供安装包下载&#xff0c;但 docker 镜像尚未更新。 在 MySQL 8.1.0 刚发版时也做过分析&#xff0c;欢迎阅读&#xff1a; 重…

【话题】我眼神的IT行业现状与未来趋势

目录 一、挑战 教学资源的重新分配 教师角色的转变 学生学习方式的改变 教育评价体系的挑战 二、机遇 个性化学习 跨学科学习 国际合作与交流 创新教育模式 三、如何培养下一代IT专业人才 更新教育理念 加强基础设施建设 整合课程资源 加强实践教学 培养跨学科…

4月空调行业线上市场销售数据分析

随着生活品质的提升&#xff0c;消费者对家用空调的诉求不仅仅满足于基本制冷制热功能&#xff0c;而是在环保节能、功能升维、舒适送风、智能科技、焕新设计等多维度提出需求。这种多样化的需求推动了空调产品的创新和升级&#xff0c;这不仅提高了空调的市场竞争力&#xff0…

【python】随笔 - 知识点小课堂 -13.数据分析、科学计算与可视化

前言 本文是关于数据分析、科学计算与可视化的习题整理和讲解 13.1 假设已执行语句import numpy asnp和xnp.array((1&#xff0c;2,3,45))&#xff0c;那么表达式 sum(x*2)的值为 结果是30&#xff0c;因为数组x中的元素是[1, 2, 3, 4, 5]&#xff0c;将每个元素乘以2后得到…

达梦数据库使用dmlcvt命令找回更改前的数据

在生产系统上不小心修改了表数据后最快的方法是用闪回查询找回。但时间不能超过undo_retention&#xff08;默认90秒&#xff09;。其实最标准的处理方法是在其他机器上将数据库恢复到修改前的时刻。但数据库比较大时恢复时间较长。真实场景可能比较急。那么也可以分析归档日志…

kubernetes之prometheus kube-controller-manager。 scheduler报错问题

项目场景&#xff1a; prometheus scheduler及kube-controller-manager监控报错 问题描述 kubeadm搭建完kube-prometheus 会有这个报错 原因分析&#xff1a; rootmaster2:~# kubectl describe servicemonitor -n kube-system kube-controller-manager通过以上图片我们发现 k…

东哥一句兄弟,你还当真了?

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 你还真把自己当刘强东兄弟了?谁跟你是兄弟了?你在国外的房子又不给我住&#xff0c;你出去旅游也不带上我!都成人年了&#xff0c;东哥一句客套话&#xff0c;别当真! 今天&#xff0c;东哥在高管会上直言&…

从零训练yolov8

1.收集数据 2.数据标注 pip install labelimg3.划分数据集 0.2的验证机0.8的训练集 import os from shutil import copyfile from sys import exit import randomsource r"D:\Data\imgs\screenc" \\ target_train r"D:\Data\imgs\datasets\mydata\images\t…

生产制造边角料核算说明及ODOO演示

今天群里有伙伴提到边角料的处理问题&#xff0c;我们梳理了一下&#xff0c;在生产过程中&#xff0c;如果产生了边角料&#xff0c;核算产成品的投料成本时需要考虑边角料的价值&#xff0c;以确保成本核算的准确性。以下是注意的几点&#xff1a; 一、边角料的入账价值 在生…