蓝桥杯练习03个人博客

news2025/1/15 23:42:04

个人博客

介绍

很多人都有自己的博客,在博客上面用自己的方式去书写文章,用来记录生活,分享技术等。下面是蓝桥云课的博客,但是上面还缺少一些样式,需要大家去完善。

准备

开始答题前,需要先打开本题的项目代码文件夹,目录结构如下:

其中:
·index.css是需要补充样式的文件。
·index.html是博客页面。
·1ogo.svg是1ogo图片。
在浏览器中预览index.html页面效果如下:

目标

1.在index.css中已经给出了修改部分的提示,请仔细阅读。
2.请完善index.css上方需要修改的代码,修改完成后,页面效果如下所示:

代码

html

<!DOCTYPE html>
<html lang="en">

<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>Document</title>
	<link rel="stylesheet" href="index.css">
</head>

<body class="theme-mode-dark">
	<div class="theme-container sidebar-open no-sidebar">
		<header class="navbar blur">
			<!-- logo -->
			<a class="home-link">
				<img src="./logo.svg" class="logo">
			</a>
			<!-- 导航头部右侧内容 -->
			<div class="links" style="max-width: 863px;">
				<!-- 导航文字 -->
				<nav class="nav-links can-hide">
					<div class="nav-item">
						<a class="nav-link">首页</a>
					</div>

					<div class="nav-item">
						<a class="nav-link">关于</a>
					</div>
					<div class="nav-item">
						<a class="nav-link">收藏</a>
					</div>
					<!-- github图标 -->
					<a class="repo-link">
						GitHub
						<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px"
								y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound">
								<path fill="currentColor"
									d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z">
								</path>
								<polygon fill="currentColor"
									points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9">
								</polygon>
							</svg>
						</span>
					</a>
				</nav>
			</div>
		</header>
		<!-- banner 部分 -->
		<div class="home-wrapper">
			<div class="banner">
				<div class="banner-conent" style="padding-top: 7rem;">
					<header class="hero">
						<!---->
						<h1 id="main-title">
							蓝桥云课的博客
						</h1>
						<p class="description">
							做受人尊敬的公司
						</p>
						<!---->
					</header>
					<!---->
				</div>
				<!---->
			</div>
			<!-- 内容部分 -->
			<div class="main-wrapper">
				<div class="main-left">
					<div class="card-box article-list">
						<div class="article-title">
							<a class="iconfont icon-bi">最近更新</a>
						</div>
						<div class="article-wrapper">
							<dl>
								<dd>01</dd>
								<dt>
									<a>
										<div>
											33个非常实用的JavaScript一行代码
											<!---->
										</div>
									</a>
									<span class="date">11-02</span>
								</dt>
							</dl>
							<dl>
								<dd>02</dd>
								<dt>
									<a>
										<div>
											Hook规则
											<!---->
										</div>
									</a> <span class="date">04-06</span>
								</dt>
							</dl>
							<dl>
								<dd>03</dd>
								<dt>
									<a>
										<div>
											使用State Hook
											<!---->
										</div>
									</a>
									<span class="date">04-06</span>
								</dt>
							</dl>
							<dl>
								<dd>04</dd>
								<dt>
									<a>
										<div>
											自定义 Hook
											<!---->
										</div>
									</a>
									<span class="date">04-06</span>
								</dt>
							</dl>
							<dl>
								<dd>05</dd>
								<dt>
									<a>
										<div>
											使用Effect Hook
											<!---->
										</div>
									</a>
									<span class="date">04-06</span>
								</dt>
							</dl>
							<dl>
								<dd>06</dd>
								<dt>
									<a>
										<div>
											Hook概述
											<!---->
										</div>
									</a>
									<span class="date">03-31</span>
								</dt>
							</dl>
							<dl>
								<dd>07</dd>
								<dt><a href="/pages/87146f/" class="">
										<div>
											案例演示
											<!---->
										</div>
									</a> <span class="date">03-27</span></dt>
							</dl>
							<dl>
								<dd>08</dd>
								<dt>
									<a class="">
										<div>
											React哲学
											<!---->
										</div>
									</a>
									<span class="date">03-26</span>
								</dt>
							</dl>
							<dl>
								<dd></dd>
								<dt>
									<a>更多文章&gt;</a>
								</dt>
							</dl>
						</div>
					</div>

				</div>

				<div class="main-right">
					<!-- 右侧头像和简介 -->
					<aside class="blogger-wrapper card-box">

						<!---->
						<div class="blogger"><span class="name">蓝桥</span> <span class="slogan">前端博客</span></div>
					</aside>
					<!-- 右侧文章分类 -->
					<div class="categories-wrapper card-box">
						<a class="title iconfont icon-wenjianjia" title="全部分类">文章分类</a>
						<div class="categories">
							<a class="">
								更多
								<span>12</span>
							</a>
							<a class="">
								实用技巧
								<span>2</span>
							</a>
							<a class="">
								jsx教程
								<span>1</span></a>
							<a class="">
								前端
								<span>15</span>
							</a>
							<a class="">
								JavaScript文章
								<span>12</span>
							</a>
							<a class="">
								《React》笔记
								<span>18</span>
							</a>
							<a class="">
								Hook
								<span>5</span>
							</a>
							<a class="">
								案例演示
								<span>1</span>
							</a>
							<a class="">
								核心概念
								<span>11</span>
							</a>
							<a class="">
								高级指引
								<span>1</span>
							</a>
							<a class="more">更多 ...</a>

						</div>
					</div>
				</div>
			</div>

		</div>
</body>

</html>

css

/* TODO:banner 上的文字 需要居中显示 */

/* TODO: main-wrapper 通过设置main-wrapper 布局方式 让.main-left  .main-right 正确显示 */

/*/* TODO 宽度自适应 居左显示 */

/* 宽 245px 居右显示 */


/* 以下代码不需要修改 */

.navbar .links {
    padding-left: 1.5rem;
    box-sizing: border-box;
    white-space: nowrap;
    font-size: 0.9rem;
    position: absolute;
    right: 1.5rem;
    top: 0.7rem;
    display: flex;
}

.nav-links .nav-item {
    position: relative;
    margin-left: 1.5rem;
    line-height: 2rem;
    color: var(--textColor);
    display: inline-block;
}

.blogger-wrapper .avatar {
    width: 100%;
    overflow: hidden;
}

.card-box {
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 10%);
    transition: box-shadow 0.5s;
}

.blogger-wrapper .avatar img {
    width: 100%;
    height: 100%;
}

.banner {
    background: rgb(17, 130, 182);
}

.theme-mode-dark {
    --bodyBg: #27272b;
    --mainBg: #1e1e22;
    --sidebarBg: rgba(30, 30, 34, 0.8);
    --blurBg: rgba(30, 30, 34, 0.8);
    --textColor: #000000;
    --textLightenColor: #0085ad;
    --borderColor: #2c2c3a;
    --codeBg: #252526;
    --codeColor: #fff;
}

.theme-container {
    color: var(--textColor);
    min-height: 100vh;
}

.article-list .article-title {
    border-bottom: 1px solid var(--borderColor);
    font-size: 1.3rem;
    padding: 1rem;
}

.nav-links .repo-link {
    margin-left: 1.5rem;
    color: var(--textColor);
}

.navbar a,
.navbar span,
.navbar img {
    display: inline-block;
}

.nav-links a {
    line-height: 1.4rem;
    color: inherit;
}

.navbar .links .search-box {
    flex: 0 0 auto;
    vertical-align: top;
}

.search-box {
    display: inline-block;
    position: relative;
    margin-right: 1rem;
}

.avbar {
    padding: 0.7rem 1.5rem;
    line-height: 2.2rem;
    transition: transform 0.3s;
}

.navbar {
    z-index: 20;
    top: 0;
    left: 0;
    right: 0;
    height: 3.6rem;
    box-sizing: border-box;
    box-shadow: 0 2px 5px rgb(0 0 0 / 6%);
}

body .search-box input {
    background-color: transparent;
    color: var(--textColor);
    border: 1px solid var(--borderColor, #ccc);
}

.article-list .article-wrapper {
    overflow: hidden;
}

.article-list .article-wrapper dl {
    border-bottom: 1px dotted var(--borderColor);
    float: left;
    display: flex;
    padding: 8px 0;
    margin: 0;
    height: 45px;
    width: 100%;
}

header {
    display: block;
}

.home-wrapper .banner {
    width: 100%;
    min-height: 450px;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.article-list .article-wrapper dl dt a {
    color: var(--textColor);
    flex: 1;
    display: flex;
    height: 45px;
    align-items: center;
    font-weight: normal;
}

.article-list .article-wrapper dl dt {
    flex: 1;
    display: flex;
}

.article-list .article-wrapper dl dd {
    font-size: 1.1rem;
    color: #f17229;
    width: 50px;
    text-align: center;
    margin: 0;
    line-height: 45px;
}

dd {
    display: block;
    margin-inline-start: 40px;
}

.article-list .article-wrapper dl dt .date {
    width: 50px;
    margin-right: 15px;
    color: #999;
    text-align: right;
    font-size: 0.9rem;
    line-height: 45px;
}

.search-box input {
    cursor: text;
    width: 10rem;
    height: 2rem;
    color: #4e6e8e;
    display: inline-block;
    border: 1px solid #cfd4db;
    border-radius: 2rem;
    font-size: 0.9rem;
    line-height: 2rem;
    padding: 0 0.5rem 0 2rem;
    outline: none;
    transition: all 0.2s ease;
}

a,
input,
button {
    outline: none;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
    -webkit-focus-ring-color: rgba(0, 0, 0, 0);
}

.home-wrapper .main-wrapper {
    margin-top: 2rem;
}

.home-wrapper .main-wrapper .main-left .card-box {
    margin-bottom: 0.9rem;
}

.article-list {
    padding: 1rem 2rem;
}

.main-wrapper .main-right .card-box {
    margin: 0 0 0.9rem 0.9rem;
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
}

.blogger-wrapper {
    height: auto;
    display: inline-table;
    padding-top: 0 !important;
    overflow: hidden;
}

.categories-wrapper .categories {
    margin-top: 0.6rem;
}

.categories-wrapper .categories a {
    display: block;
    padding: 8px 0.95rem 7px 0.95rem;
    color: var(--textColor);
    opacity: 0.8;
    font-size: 0.95rem;
    line-height: 0.95rem;
    position: relative;
    transition: all 0.2s;
    border-left: 2px solid transparent;
    margin-top: -1px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

a {
    font-weight: 500;
    color: #11a8cd;
    text-decoration: none;
}

a,
input,
button {
    outline: none;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
    -webkit-focus-ring-color: rgba(0, 0, 0, 0);
}

.categories-wrapper .categories a span {
    float: right;
    background-color: var(--textColor);
    color: #fff;
    border-radius: 8px;
    padding: 0 0.13rem;
    min-width: 1rem;
    height: 1rem;
    line-height: 1rem;
    font-size: 0.6rem;
    text-align: center;
    opacity: 0.6;
    transition: opacity 0.3s;
}

.blogger-wrapper .blogger {
    padding: 0.3rem 0.95rem 0 0.95rem;
}

.blogger-wrapper .blogger .name {
    font-size: 1.3rem;
    display: block;
    margin-bottom: 6px;
}

.blogger-wrapper .blogger .slogan {
    color: var(--textColor);
}

.blogger-wrapper .blogger .name {
    color: var(--textColor);
}

.categories-wrapper .title {
    color: var(--textColor);
    opacity: 0.9;
    font-size: 1.2rem;
    padding: 0 0.95rem;
}

.navbar {
    padding: 0.7rem 1.5rem;
    line-height: 2.2rem;
    transition: transform 0.3s;
}

.navbar a,
.navbar img,
.navbar span {
    display: inline-block;
}

答案

/* TODO:banner 上的文字 需要居中显示 */

.home-wrapper .banner .banner-conent .hero {
    margin-top: 3rem;
    text-align: center;
}


/* TODO: main-wrapper 通过设置main-wrapper 布局方式 让.main-left  .main-right 正确显示 */

.main-wrapper {
    margin: 1.5rem auto 0 auto;
    max-width: 1100px;
    padding: 0 0.9rem;
    box-sizing: border-box;
    position: relative;
    display: flex;
}


/*/* TODO 宽度自适应 居左显示 */

.main-wrapper .main-left {
    width: auto;
    float: left;
}


/* 宽 245px 居右显示 */

.main-wrapper .main-right>* {
    width: 245px;
}

考点:

  1. CSS 选择器
    • 类选择器:通过.符号引用类名(例如 .home-wrapper.banner.banner-content.hero.main-wrapper.main-left.main-right)。
    • 后代选择器:两个或多个选择器之间无特殊符号,表示后者必须是前者后代元素(例如 .home-wrapper .banner .banner-content .hero)。
    • 子元素选择器(直接子元素选择器):使用 > 符号,表示只选择作为指定父元素的直接子元素的元素(例如 .main-wrapper .main-right > *)。
  2. CSS 样式属性
    • margin:设置元素的外边距。
    • text-align:设置元素内文本内容的水平对齐方式。
    • max-width:设置元素的最大宽度。
    • padding:设置元素的内边距。
    • box-sizing:设置元素的盒模型计算方式,border-box 表示包括内边距和边框在内的总尺寸。
    • position:设置元素的定位方式,relative 表示相对定位。
    • display:设置元素的显示模式,flex 表示弹性布局。
    • width:设置元素的宽度。
    • float:浮动属性,用于将元素放置到一边,但在这个上下文中,由于已经应用了 Flexbox 布局,可能不需要使用。
  3. Flexbox 相关概念: 虽然代码片段中没有明确提到具体的 Flexbox 属性,但在 .main-wrapper 中设置了 display: flex,表明这个容器会采用 Flexbox 布局方式,它的子元素(.main-left.main-right)将会按照 Flexbox 规则排列和显示。在实际应用中,可能会结合其他 Flexbox 属性(如 flex-directionjustify-contentalign-items 等)进一步控制布局效果。

小结:本题考的主要是css的使用,用的rem布局,在不同的设备显示效果比较好。

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

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

相关文章

SPI读写学习

走到初衷使用STM32的地方&#xff0c;例子是读写W25Q&#xff0c;但是手上没有25Q&#xff0c;只有一个SPI接口的SD卡。在UNO上已经实验OK&#xff0c;线接好后&#xff0c;发现SD卡里有个寄存器转换表&#xff0c;跟例子的SPI接口不一样&#xff0c;要改的太多。 u32 SPI_FLAS…

修复打印机不能打印的10种方法,总有一种适合你

前言 技术有时很奇怪,我们可以用声音控制恒温器,但有时打印机会像15年前一样令人困惑和不可靠。如果打印机向你抛出错误(或完全忽略你的要求),可能有许多原因。 不幸的是,仅仅找出问题才成功一半,另一半是解决方案,它将使你的打印机重新工作。下面是如何解决问题的方…

CTF题型 php反序列化进阶(1) php原生类 例题和总结

CTF题型 php反序列化进阶(1) php原生文件操作类 例题和总结 文章目录 CTF题型 php反序列化进阶(1) php原生文件操作类 例题和总结特征原理 我们可以通过PHP自身本来就有的类来进行文件操作扫描目录的三个类DirectoryIterator(支持glob://协议)FilesystemIterator&#xff08;继…

【黑马头条】-day01环境搭建SpringBoot-Cloud-Nacos

文章目录 1 环境搭建及简介2 项目介绍2.1 应用2.2 业务说明2.3 技术栈2.4 收获2.5 大纲 3 Nacos准备3.1 安装Nacos 4 初始工程搭建4.1 环境准备4.1.1 导入项目4.1.2 设置本地仓库4.1.3 设置项目编码格式 4.2 全局异常4.2.1 自动装配 4.3 工程主体结构 5 登录功能开发5.1 需求分…

关于《动手学深度学习》找不到d2l.......和#@save的思考

在运行书上的代码时&#xff0c;会出现报错。 最后通过简单粗暴的方法解决了这个问题&#xff0c;在此记录一下。 一、#save是什么 # 表明是注释&#xff0c;所以这句话对代码没有影响&#xff0c;只是一个“标识”&#xff0c;表明在d2l文档中&#xff0c;作者已经写好了这…

实用翻译英语的Chrome插件

工作中&#xff0c;时常需要阅读网页技术文档&#xff0c;阅读英语技术论文&#xff0c;对翻译的需求很迫切&#xff1b; Chrome默认的翻译比较呆板&#xff1b; 这边推介更加智能的双语翻译&#xff0c;同时支持pdf翻译&#xff0c;下载地址&#xff1a; https://chrome.goo…

设计模式之简单工厂模式详解

简单工厂模式 工厂模式&#xff1a;工厂方法模式&#xff1b; 低阶&#xff1a;简单工厂模式&#xff1b; 高阶&#xff1a;抽象工厂模式&#xff1b; 1&#xff09;概述 定义一个工厂类&#xff0c;根据参数的不同返回不同类的实例&#xff0c;被创建的实例通常都具有共同…

设备安全与设备管理系统的融合发展之路

随着企业运营的不断复杂化和市场竞争的加剧&#xff0c;设备安全与设备管理系统的融合发展已经成为企业追求卓越运营、实现持续发展的必经之路。这种融合不仅提升了设备的安全性&#xff0c;更提高了设备管理的效率与精准度&#xff0c;为企业的整体运营奠定了坚实基础。 一、设…

华为机试真题练习汇总(81~90)

华为机试真题练习汇总&#xff08;81~90&#xff09; 华为机试真题练习汇总&#xff08;81~90&#xff09;HJ81 字符串字符匹配** HJ82 将真分数分解为埃及分数HJ83 二维数组操作HJ84 统计大写字母个数HJ85 最长回文子串HJ86 求最大连续bit数HJ87 密码强度等级* HJ88 扑克牌大小…

Go语言实战:深入掌握标准库flag的强大用法

Go语言实战&#xff1a;深入掌握标准库flag的强大用法 引言flag库基础命令行参数的基本概念使用flag库定义和解析命令行参数处理非选项命令行参数小结 高级用法自定义Flag的解析命令行参数的分组和嵌套小结 实战技巧组织复杂命令行应用的参数错误处理和用户帮助信息调试命令行应…

PHP 服务实现监控可观测性最佳实践

前言 本次实践主要是介绍 PHP 服务通过无侵入的方式接入观测云进行全面的可观测。 环境信息 主机环境&#xff1a;CentOS 7.8PHP&#xff1a;7.4.33MySQL&#xff1a;5.7 接入方案 准备工作 安装 DataKit # 需要把token 改成观测云空间的实际token值&#xff08;可在观测…

G*T、文心一言微信 AI 机器人的时代已经来临!

前言 在当今的科技时代&#xff0c;人工智能&#xff08;AI&#xff09;的发展速度可谓是日新月异。其中&#xff0c;自然语言处理&#xff08;NLP&#xff09;领域的模型&#xff0c;如 G*T、文心一言等&#xff0c;已经成为了 AI 领域的主流。不仅如此&#xff0c;将 AI 接入…

铸铁平台制造工艺有多精细你知道吗——河北北重

铸铁平台的制造工艺要求相对较高&#xff0c;需要经过以下精细工艺&#xff1a; 材料选择&#xff1a;铸铁平台通常使用灰口铸铁&#xff0c;其具有良好的耐磨性和强度。材料的选择要考虑到使用环境和平台的功能需求。 模具制造&#xff1a;根据设计要求制作模具&#xff0c;模…

算法---二分查找练习-3(山脉数组的顶峰索引)

山脉数组的顶峰索引 1. 题目解析2. 讲解算法原理3. 编写代码 1. 题目解析 题目地址&#xff1a;点这里 2. 讲解算法原理 初始化两个指针 left 和 right&#xff0c;分别指向数组的起始位置和结束位置。 进入循环&#xff0c;循环条件为 left < right。 在每次循环中&…

全平台(淘宝1688京东)商品详情API接口(item_get-获得全平台商品详情接口)

全平台商品详情API接口&#xff08;item_get-获得全平台商品详情接口&#xff09;&#xff0c;全平台API接口可获取到商品链接&#xff0c;商品ID&#xff0c;商品标题&#xff0c;商品价格&#xff0c;品牌名称&#xff0c;店铺昵称&#xff0c;sku规格&#xff0c;sku属性&am…

自注意力机制的理解

一、自注意力要解决什么问题 循环神经网络由于信息传递的容量以及梯度消失问题&#xff0c;只能建立短距离依赖关系。为了建立长距离的依赖关系&#xff0c;可以增加网络的层数或者使用全连接网络。但是全连接网络无法处理变长的输入序列&#xff0c;另外&#xff0c;不同的输…

【Android】【Bluetooth Stack】蓝牙电话本协议之同步通讯录分析(超详细)

1. 精讲蓝牙协议栈&#xff08;Bluetooth Stack&#xff09;&#xff1a;SPP/A2DP/AVRCP/HFP/PBAP/IAP2/HID/MAP/OPP/PAN/GATTC/GATTS/HOGP等协议理论 2. 欢迎大家关注和订阅&#xff0c;【蓝牙协议栈】专栏会持续更新中.....敬请期待&#xff01; 目录 1. 协议简述 1.1 PBAP…

【十二】【算法分析与设计】滑动窗口(3)

30. 串联所有单词的子串 给定一个字符串 s 和一个字符串数组 words。 words 中所有字符串 长度相同。 s 中的 串联子串 是指一个包含 words 中所有字符串以任意顺序排列连接起来的子串。 例如&#xff0c;如果 words ["ab","cd","ef"]&#xff…

【Godot4.2】 基于SurfaceTool的3D网格生成与体素网格探索

概述 说明&#xff1a;本文基础内容写于2023年6月&#xff0c;由三五篇文章汇总而成&#xff0c;因为当时写的比较潦草&#xff0c;过去时间也比较久了&#xff0c;我自己都得重新阅读和理解一番&#xff0c;才能知道自己说了什么&#xff0c;才有可能重新优化整理。 因为我对…

使用WordPress在US Domain Center上建立摄影网站的详细教程

第一部分&#xff1a;介绍摄影网站 摄影网站是摄影师展示作品、分享经验、提供服务的在线平台。在摄影网站上&#xff0c;摄影师可以展示自己的摄影作品、发布摄影日志、接受客户预约等。使用WordPress搭建摄影网站具有灵活性和可扩展性&#xff0c;可以通过选择适合的主题和插…