0

0

CSS网格中的文字环绕_结合CSS Shapes实现特殊排版

P粉602998670

P粉602998670

发布时间:2026-02-14 12:57:10

|

773人浏览过

|

来源于php中文网

原创

css grid中文字环绕无效,因grid子项脱离文档流;需将图形移至grid外用float+shape-outside实现,再通过负margin视觉归位,且svg路径须闭合、无冗余元素,safari尚不支持shape-outside:url()。

css网格中的文字环绕_结合css shapes实现特殊排版

文字环绕在CSS Grid里根本不起作用

CSS Grid本身不支持shape-outside,哪怕你给网格项加了浮动或shape-outside,文字也不会绕着它走——因为Grid容器会把子项当作独立的轨道单元来布局,完全忽略传统浮动流的规则。

真正能触发文字环绕的,只有参与文本流的元素(比如float布局中的imgdiv),而Grid子项默认脱离普通文档流(即使没设position: absolute)。

所以别试grid-area里塞shape-outside,它不会生效。

想让文字绕着Grid里的图形走,得“骗过”浏览器的流式上下文

核心思路:把需要被环绕的图形抽出来,放在Grid容器外部,用float + shape-outside驱动环绕;再用margintransform把它视觉上“塞回”Grid布局中。

立即学习前端免费学习笔记(深入)”;

常见做法:

  • Grid容器保持结构清晰,只放纯文本内容(比如<p></p><article></article>
  • 把图形(如SVG或PNG)作为兄弟元素放在Grid容器外层,设float: leftshape-outside: url(...)shape-outside: polygon(...)
  • 用负margin(如margin-left: -120px)把图形拉进Grid区域,对齐视觉位置
  • 确保图形的width/height固定,否则shape-outside可能计算错边界

示例关键片段:

  <div class="grid-wrapper">
    @@##@@
    <div class="grid-content">
      <p>这里是一大段文字……</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/745" title="What-the-Diff"><img
                                                                                src="https://img.php.cn/upload/ai_manual/001/503/042/68b6dc516822a519.png" alt="What-the-Diff"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/745" title="What-the-Diff">What-the-Diff</a>
                                                                        <p>检查请求差异,自动生成更改描述</p>
                                                                </div>
                                                                <a href="/ai/745" title="What-the-Diff" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>
    </div>
  </div>

.float-shape需设float: leftshape-outside: url(figure.svg)widthheight,且figure.svg必须有透明背景和明确路径。

SVG作为shape-outside源时,90%失败是因为路径问题

不是所有SVG都能当shape-outside用。浏览器只读取第一个<path></path>,且该路径必须是闭合的(d属性以Z结尾),坐标系要基于SVG的viewBox原点。

容易踩的坑:

  • 导出SVG时勾选了“响应式”,导致width/heightauto → 浏览器无法解析尺寸 → shape-outside静默失效
  • 路径用了fill-rule: evenodd但未闭合 → 实际形状为空白
  • SVG里带<g></g>包裹或多余<defs></defs> → 必须手动删到只剩一个<path></path>
  • 用Figma/Adobe XD直接导出 → 常含transform属性 → 需手动提取绝对坐标或用工具转成静态d

调试建议:先用shape-outside: circle(50px)确认环绕逻辑通了,再换SVG。

Grid + Shapes在Safari里大概率不工作

截至 Safari 17.4,shape-outside仍不支持url()语法(仅支持circle/polygon/inset),而且对float元素的环绕计算常错位。

如果你的目标用户包含大量Mac/iOS用户,要么:

  • 改用shape-outside: polygon(...)硬编码轮廓(适合简单图形)
  • 降级方案:用@supports (shape-outside: circle())做特性检测,fallback为左右两栏Grid(图文分离)
  • 彻底放弃环绕,改用clip-path裁剪图片+Grid间隙留白模拟“绕行感”

别指望display: flow-rootcontain: layout能修好Safari的Shapes bug——它就是没实现。

最麻烦的其实是响应式:图形尺寸一变,polygon坐标就得重算,而SVG的viewBox缩放又和shape-outside解析不完全同步。这点连Chrome都偶尔抽风。

CSS网格中的文字环绕_结合CSS Shapes实现特殊排版

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

942

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

777

2023.11.06

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

587

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

104

2025.10.23

CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

83

2023.11.23

margin在css中是啥意思
margin在css中是啥意思

在CSS中,margin是一个用于设置元素外边距的属性。想了解更多margin的相关内容,可以阅读本专题下面的文章。

452

2023.12.18

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

22

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

11

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

7

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 31万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号