记录一个显示svg图标遇到的问题及解决方案

我们写了一个h5活动页面放在微信公众号上,该页面有一个 svg 的小图标,我一开始直接使用了 img 标签进行显示,结果在 iphone 设备上,该图标渲染出来有一些模糊。经过查询资料才知道,在 iphone 设备上,img 标签引入的 svg 会被解析成普通的 png 图片,分辨率还很低。

于是我使用了 object 标签来显示图标,这下是清晰了,但是我为 object 或者他的父级 div 设置点击事件却没了反应,经过一番尝试,有了以下解决方案:

html 复制代码
<div class="icon">
  <object type="image/svg+xml" data="xxx"></object>
  <div class="click-layer" @click="alert('hello')"></div>
</div>

<style>
.icon {
  position: relative;
}
.icon .click-layer {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: transparent;
}
</style>

就是给图标加一个透明的层盖住,然后给这个层加点击事件,完美!

相关推荐
Roc.Chang4 分钟前
Vite 启动报错:listen EACCES: permission denied 0.0.0.0:80 解决方案
linux·前端·vue·vite
Desirediscipline16 分钟前
cerr << 是C++中用于输出错误信息的标准用法
java·前端·c++·算法
sunny_16 分钟前
前端构建产物里的 __esModule 是什么?一次讲清楚它的原理和作用
前端·架构·前端工程化
Soulkey2 小时前
复刻小红书Web端打开详情过渡动画
前端
yuki_uix2 小时前
你点了「保存」之后,数据都经历了什么?
前端
猪头男2 小时前
【从零开始学习Vue|第六篇】生命周期
前端
zheshiyangyang3 小时前
前端面试基础知识整理【Day-7】
前端·面试·职场和发展
猫头虎4 小时前
web开发常见问题解决方案大全:502/503 Bad Gateway/Connection reset/504 timed out/400 Bad Request/401 Unauthorized
运维·前端·nginx·http·https·gateway·openresty
qq_24218863324 小时前
3389端口内网转发概述
前端·经验分享·html
伊泽瑞尔4 小时前
2025年终总结
前端·程序员·ai编程