深入CSS-001

啥是"流"

流实际上是CSS中的一种基本的定位和布局机制

啥是流体布局

指的是利用元素流的特性实现的各类布局效果。因为流本身具有自适应特性,所以流体布局也具有自适应性 注意:流的特性不适用于table标签

块级元素

有div、li、table等 注意:块级元素和display是block的元素不是一个概念 块级元素独占一行的特性,导致理论上都可以配合clear属性清除浮动带来的影响

标记盒子

list-item本来是没有的圆点那些东西,但是列表需要有,就在list-item外面添加了附加盒子

inline-block的原理

通过两个盒子构成,外面的盒子负责处理是一行还是换行,内部盒子负责宽高和内容的显示

深入width:auto

width的默认值是auto,有4种不同的宽度表现 1、可充分利用空间 2、收缩与包裹,典型代表如浮动、绝对定位等 3、收缩到最小 4、超出容器限制 注意:布局应使用无宽度布局,可以减少代码、减少计算、减少维护,避免由于宽度改变重新运算宽度 对于一个元素,如果其display属性值是inline-block,那么即使其里面内容再多,只要是正常文本,宽度也不会超过容器 按钮就是CSS中极具代表性的inline-block元素,具体表现为:按钮文字越多宽度越宽(内部尺寸特性),但如果文字足够多,则会在容器的宽度处自动换行(自适应性) 按钮最大宽度就是容器的240像素

首选最小宽度

由于换行等问题,CSS的设计者让首选最小宽度不会打断整个文字 东亚文字:最小宽度为每个汉字的宽度 西方文字:一般会终止于空格、短横线、问号等非英文字符

盒尺寸

CSS流体布局下的宽度分离原则:就是CSS中的width属性不与影响胯宽度的padding/border属性共存 具体写法是width独立占用一层标签,而padding、border、margin利用流动性在内部自适应性呈现

css 复制代码
.father {
  width: 204px;
}

.child {
  border: 1px solid;
  padding: 20px;
}

这样写就可以得到距离边框20像素的内容

box-sizing的作用

盒尺寸是改变了width作用的盒子,在使用box-sizing之后,就可作用到其他盒子,如content-box、padding-box等

深入height

CSS中默认流是水平方向,宽度是稀缺的,高度是无限的

height:100%

对于width属性,就算父元素width为auto,其百分比也是支持的,但是对于height属性,如果父元素height为auto,只要子元素在文档流中,其百分比就完全被忽略 不了解就会写成这样(我也写出过这样的问题),不会有任何效果

css 复制代码
div {
  width: 100%; /*多余的*/
  height: 100%; /*无效的*/
  background-color: blue;
}

原因是对于普通的文档流,百分比高度值要想起作用父级必须要有个可以生效的高度值

height:100%无效的原因

如果包含块的高度没有显式指定,并且该元素不是绝对定位,则计算值为auto

如何让元素支持height:100%

1、设定显示高度值 2、使用绝对定位,position:absolute

最大最小宽高

min-width/max-width出现的场景一定是自适应布局或者流体布局 为了避免图片在移动端展示过大影响体验,常常会有max-width限制 强制height为auto可以确保宽度不超出同事使图片保持原来的比例 max-width和max-height的默认值是none,min-width和min-height默认值是...... 超越!important指的是max-width会覆盖width

相关推荐
牛奶2 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶2 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol4 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路5 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide5 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter6 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸6 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000007 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉7 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化