文字环绕浮动图片需用float:left/right,图片须为普通流内元素并设width和margin;后续块级元素可能清除浮动导致环绕失效,关键在父容器与兄弟元素的样式交互。
直接用 float: left 或 float: right 就能触发文字环绕,但必须确保图片是**普通流内元素**(不能是 position: absolute 或 display: inline-block 且未设宽高导致脱离文本流),且文字内容是后续的块级或行内内容。
关键点:浮动只影响**后续的块级框(block-level boxes)的布局边界**,不影响浮动元素自身的盒模型尺寸计算。
float 元素会脱离文档流,但文字(作为行内内容)会自动绕开其占据的空间width,否则可能撑满父容器,失去“环绕”效果margin(如 margin-right 或 margin-left)来控制文字与图片的间距,避免紧贴典型现象是图片下

overflow: hidden / auto 且没给高度,可能意外清除浮动(取决于渲染引擎)div 等块级元素,且该元素有 clear: both(显式或通过 BFC 触发)inline 元素(如没设 display: block),浮动后基线对齐异常,导致文字“卡住”margin,文字紧贴图片边缘,视觉上像没环绕(实际已环绕,只是难察觉)margin 不是可选装饰,而是控制环绕体验的核心参数。它决定文字从哪条边开始折行。
float: left → 推荐加 margin-right: 12px,让右侧文字保持呼吸感float: right → 推荐加 margin-left: 12px,同理margin-top/margin-bottom)会影响图片在段落中的垂直位置,但**不会影响环绕逻辑**float + margin 的解析有细微差异,若需兼容,避免 margin 值为百分比或负值.wrap img {
float: left;
width: 150px;
margin-right: 12px;
margin-bottom: 6px;
}
float 本意是为印刷排版服务的,CSS 多列、shape-outside 和 display: flow-root 才是更可控的环绕手段。但目前仍需支持旧浏览器时,float 最稳妥。
shape-outside 可实现文字绕椭圆/多边形图片,但 Safari 对非 circle()/inset() 形状支持不稳定display: flow-root 可安全包裹浮动子元素,避免父容器塌陷,比 overflow: hidden 更语义化p 标签里时