CSS【详解】布局 display ( 含 flex 布局,grid 布局,table 布局,float 布局,响应式布局 等)

简介: CSS【详解】布局 display ( 含 flex 布局,grid 布局,table 布局,float 布局,响应式布局 等)

display:none 隐藏布局

  • 用于隐藏元素,不会占用页面空间;
  • 给 html 标签设置 hidden 属性,其效果即将其 display 设置为 none
<div hidden>我被隐藏了</div>
  • visibility: hidden 也能隐藏元素,但该元素仍会占用页面空间

display:inline 行内布局

元素从左到右排列成一行,元素的宽度由内容决定,不能设置宽高(替换元素除外)。

display:inline-block 行内块布局

元素从左到右排列成一行,可以设置宽高

display:block 块布局

每个元素撑满整行,多个块元素在一起时,效果如同从上向下排队。

display:flex 弹性布局(伸缩布局)

https://www.runoob.com/w3cnote/flex-grammar.html

更多详解和实战范例可参考:

flex: initial、flex:0、flex:1、flex:none、flex:auto的区别和使用场景

https://blog.csdn.net/weixin_41192489/article/details/120846362

深入理解flex布局中的剩余空间分配规则——flex-grow,flex-shrink和flex-basis

https://blog.csdn.net/weixin_41192489/article/details/120842902

flex-grow 自适配宽度避免内容超出挤压两侧的最佳实践

https://blog.csdn.net/weixin_41192489/article/details/139058300

flex布局中使用margin:auto智能分配剩余空间

https://blog.csdn.net/weixin_41192489/article/details/120834852

【实战】用 flex 布局绘制骰子(一、二、三【含斜三点】、四、五、六点)

https://blog.csdn.net/weixin_41192489/article/details/136398234

display:grid 网格布局(栅格布局)

https://blog.csdn.net/weixin_41192489/article/details/115588135

display:table 表格布局

通过添加样式display:table,display:table-row,display:table-cell 等,使 HTML 元素像 <table> 标签组一样进行布局。

描述
table 此元素会作为块级表格来显示(类似 <table>),表格前后带有换行符。
inline-table 此元素会作为内联表格来显示(类似 <table>),表格前后没有换行符。
table-row-group 此元素会作为一个或多个行的分组来显示(类似 <tbody>)。
table-header-group 此元素会作为一个或多个行的分组来显示(类似 <thead>)。
table-footer-group 此元素会作为一个或多个行的分组来显示(类似 <tfoot>)。
table-row 此元素会作为一个表格行显示(类似 <tr>)。
table-column-group 此元素会作为一个或多个列的分组来显示(类似 <colgroup>)。
table-column 此元素会作为一个单元格列显示(类似 <col>
table-cell 此元素会作为一个表格单元格显示(类似 <td><th>
table-caption 此元素会作为一个表格标题显示(类似 <caption>

最常用的是单元格布局 display:table-cell,配合 text-alignvertical-align 调整元素的位置。

  • 左对齐【默认值】 text-align: left
  • 水平居中 text-align: center
  • 右对齐 text-align: right
  • 顶部对齐【默认值】 vertical-align: top
  • 垂直居中 vertical-align: middle;
  • 底部对齐 vertical-align: bottom;

【实战】div 内元素水平垂直居中

<template>
  <div class="tableDemo">表格布局</div>
</template>

<style scoped>
.child {
  /* 表格单元格布局 */
  display: table-cell;
  /* 水平居中 */
  text-align: center;
  /* 垂直居中 */
  vertical-align: middle;
  height: 100px;
  width: 100px;
  border: 1px solid black;
}
</style>

有点过时的布局

display 还有很多其他样式值,如列表元素 li 的 list-item 等,但不常用,也没有用于整个页面的布局,可以忽略

但除 display 外,还有很多其他布局方式:

float 浮动布局

  • float:left 左浮动
  • float:right 右浮动
  • float:none 取消浮动

<template>
  <h1>浮动布局前</h1>
  <div>
    <div class="Demo"></div>
    <span>
      央视网消息:杭州市气象台2024年7月4日14时15分发布的短期天气预报。受副热带高压控制,预计未来5-7天杭州市以晴热高温天气为主,最高气温可达36到38度,请注意做好防暑降温工作。
    </span>
  </div>

  <h1>浮动布局后</h1>
  <div>
    <div class="Demo floatRight"></div>
    <span>
      央视网消息:杭州市气象台2024年7月4日14时15分发布的短期天气预报。受副热带高压控制,预计未来5-7天杭州市以晴热高温天气为主,最高气温可达36到38度,请注意做好防暑降温工作。
    </span>
  </div>
</template>

<style scoped>
.floatRight {
  float: right;
}
.Demo {
  height: 30px;
  width: 30px;
  background-color: green;
}
</style>
  • float 的元素会脱离文档流(文字内容向上移动占据了第一行),但不脱离文本流(文字内容在浮动元素边缘提前换行了,以便避开浮动元素)。

float 产生的影响

  • 对自身的影响
  • 形成“块”(BFC),float值不为none的元素的display的计算值为block或table
  • 位置尽量靠上、靠左/右
  • 只有一个图片时,最终为图片宽度,若还有文本,则为设置的宽度
  • 对兄弟元素的影响
  • 不影响其他块级元素的位置
  • 影响其他块级元素的内部文本
  • 没有margin合并
  • 对父级元素的影响
  • 从父级的布局中“消失”,破坏文档流
  • 造成父级元素的高度塌陷——父级元素仅由div1 撑开后,若设置 div1 为 float ,则父级元素的高度会变为0。

清除浮动 clear

clear: both;
  • 只对块级元素有效
  • 让自身不能和前面的浮动元素相邻,对“后面的”浮动元素是不闻不问的
  • 只能在一定程度上消除浮动的影响

【实战】圣杯布局 vs 双飞翼布局 (含手写清除浮动 clearfix)

https://blog.csdn.net/weixin_41192489/article/details/136376716

格式化上下文布局 BFC 和 IFC

https://blog.csdn.net/weixin_41192489/article/details/120197275

Shapes 布局

用于实现不规则的图文环绕效果,需配合float一起使用。

https://blog.csdn.net/weixin_41192489/article/details/120978607

新兴布局 – 响应式布局

为了满足不同设备不同尺寸屏幕和分辨率的自适配显示,而新兴的 CSS 布局技术,详见链接

https://blog.csdn.net/weixin_41192489/article/details/136423056

  • 【实战】巨幅背景大标题
    https://blog.csdn.net/weixin_41192489/article/details/119009647
目录
相关文章
|
6月前
|
前端开发 算法 Java
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
213 2
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
Flex 布局 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。 一、Flex 布局是什么? Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
438 0
|
10月前
|
设计模式 容器
13.HarmonyOS流式卡片列表实现指南:Flex多行布局详解
在现代移动应用开发中,流式卡片列表是一种常见且实用的UI设计模式。它能够自适应屏幕宽度,在有限空间内高效展示多个内容项。本教程将详细讲解如何使用HarmonyOS的ArkUI框架中的Flex组件实现一个灵活的流式卡片列表,重点关注多行布局与对齐策略的应用。
337 2
|
10月前
|
开发者 UED 容器
07.精通HarmonyOS Flex对齐:从基础到高级布局技巧(上)
在HarmonyOS Next的ArkUI框架中,Flex容器提供了强大而灵活的对齐系统,使开发者能够精确控制子元素在容器中的排列方式。掌握这些对齐技术,是构建专业级用户界面的关键。
302 0
|
10月前
|
UED 容器
5.HarmonyOS Next开发宝典:掌握Flex布局的艺术
Flex布局(弹性布局)是HarmonyOS Next中最强大的布局方式之一,它提供了一种更加高效、灵活的方式来对容器中的子元素进行排列、对齐和分配空间。无论是简单的居中显示,还是复杂的自适应界面,Flex布局都能轻松应对。
296 0
|
开发者 容器
鸿蒙开发:弹性布局Flex
在实际的开发中,需要掌握主轴与交叉轴的关系、换行规则及子元素属性,同时注意性能与兼容性问题,还有一点,Flex组件在渲染时存在二次布局过程,因此在对性能有严格要求的场景下建议使用Column、Row代替。
337 10
鸿蒙开发:弹性布局Flex
|
10月前
|
UED 容器
10.HarmonyOS Next布局进阶:嵌套Flex容器与空间分配策略
在HarmonyOS Next的ArkUI框架中,Flex布局是构建用户界面的核心技术之一。通过嵌套使用Flex容器,我们可以创建复杂而灵活的界面结构,满足各种应用场景的需求。本教程将深入探讨如何在HarmonyOS Next中使用嵌套Flex容器实现复杂布局,以及如何合理分配和控制空间。
304 0
|
前端开发 容器
flex布局
【10月更文挑战第7天】
364 87
|
前端开发 UED 容器
使用 Flex 布局实现垂直居中效果
【10月更文挑战第7天】
1618 57

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    435
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    342
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    327
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    213
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    438
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    618
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    869
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    230
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    715
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    405
  • 下一篇
    开通oss服务