纯css实现关系图

CSS 关系图简介

CSS 关系图, 是指以图表形式展示 CSS 选择器以及它们之间如何相互关联、层叠和覆盖。这个概念是基于CSS的层叠性质和选择器的优先级规则。这种图形化的表示方式帮助开发者可视化地理解不同选择器的层级和优先级,以及它们是如何在文档对象模型(DOM)树上进行匹配的。

这是常见的关系图效果

CSS 关系图的组成

CSS 关系图主要组成部分包括:

  • 选择器:它是指明哪些HTML元素需要被应用样式的模式。在关系图中,选择器会以节点的形式呈现。
  • 关系:代表不同选择器之间的关系,例如后代关系、子代关系和相邻兄弟关系等。
  • 优先级:涉及特定度(Specificity)和重要性(Importance),通常由选择器的类型和结构决定。
  • 继承:某些CSS属性可从父元素传递给子元素,这在关系图上通常以箭头显示。

利用CSS关系图

在开发过程中,CSS关系图可以用来调试样式问题,优化选择器的效率,以及组织和维护项目中的CSS代码。你可以用它来确定:

  1. 选择器准确性:确保所使用的选择器能正确匹配期望的HTML元素。
  2. 继承冲突:解读哪些属性是继承来的,哪些是直接指定的。
  3. 特定度计算:理解不同选择器的权重,从而预测层叠结果。
  4. 样式覆盖:知道哪些样式会基于优先级规则覆盖其他样式。

给每一个容器添加基本样式,间距,文字居中显示

css 复制代码
.div {
  width: 80px;
  height: 80px;
  display: flex;
  background-color: aquamarine;
  /* 盒子距离 */
  margin-bottom: 50px;
  margin-right: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}

每个容器添加下线条连接,判断的依据是有无children,然后添加css 伪类样式

css 复制代码
/* 下线条 */
.xia::after {
  content: '';
  width: 1px;
  /* 线条往下的高度 */
  height: 25px;
  bottom: -25px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background-color: black;
}

上线条也是同理去实现伪类

css 复制代码
/* 上线条 */
.shang::before {
  content: '';
  width: 1px;
  /* 线条往下的高度 */
  height: 25px;
  top: -25px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background-color: black;
}

横线条在父元素添加伪类,定位到子元素的上线条上面

css 复制代码
.heng::after {
  content: '';
  /* 需要剪去盒子的大小和偏移量 */
  width: 100%;
  height: 1px;
  position: absolute;
  left: 40px;
  top: -25px;
  background-color: black;
}

最终实现的效果图

数据的结构

相关推荐
小徐不会敲代码~6 分钟前
Vue3 学习
前端·javascript·vue.js·学习
大猩猩X8 分钟前
vue vxe-gantt table 甘特图实现多个维度视图展示,支持切换年视图、月视图、周视图等
前端·javascript·甘特图·vxe-table·vxe-ui
m0_740043739 分钟前
Element-UI 组件库的核心组件及其用法
前端·javascript·vue.js·ui·elementui·html
向上的车轮13 分钟前
从“能用”到“好用”:基于 DevUI 构建高维护性、多端自适应的企业级前端架构实践
前端·架构
脾气有点小暴24 分钟前
H5 跳转方式
前端·javascript
ghfdgbg27 分钟前
11. 后端Web实战:登录认证(令牌 + 过滤器 + 拦截器)
前端
Doris89333 分钟前
【JS】JS进阶--作用域、函数、解构赋值、数组方法
开发语言·前端·javascript
黑客思维者34 分钟前
核弹级漏洞突袭React生态:RSC反序列化何以成为RCE通道?
前端·javascript·react.js·远程代码执行漏洞
K3v37 分钟前
【npm install sentry/cli】安装这个破包一直失败
前端·npm·sentry
山峰哥43 分钟前
现代 C++ 的炼金术:铸就高性能与高可维护性的工程实践
java·开发语言·前端·数据结构·c++