SVG渲染顺序及z轴显示问题(zIndex)
SVG是严格按照定义元素的顺序来渲染的,这个与HTML靠z-index值来控制分层不一样。
在SVG中,写在前面的元素先被渲染,写在后面的元素后被渲染。后渲染的元素会覆盖前面的元素,虽然有时候受透明度影响,看起来不是被覆盖的,但是SVG确实是严格按照先后顺序来渲染的。
注意:SVG是以XML定义的,所以是大小写敏感的,这点与HTML不一样。
关于z轴显示问题的解决方案:
注:动态移动对应的标签在SVG文档中的顺序,在文档结尾处的显示在z轴的上部。
Html代码
<svg style='border:1px solid blue;'> <rect class="item" width='100' height='100' style='z-index:1;' /> <circle class="item" cx='100' cy='100' r='50' style='fill:red;z-index:0;' /> </svg>
js代码:
var svg = document.getElementsByTagName('svg')[0]; var items = document.getElementsByClassName('item') for (var key in items) { if (items.hasOwnProperty(key)) { var element = items[key]; element.addEventListener('mouseenter', function (e) { svg.appendChild(e.target); }, false); } }
注:svg.appendChild(e.target); 对于已经存在的对象,则是移动了标签的位置。
在线演示地址:https://codepen.io/anon/pen/WEdXXM
更多:
分类:
SVG
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人