利用H5实现svg图片中各部分监听事件

目录

0.前言

1.效果图

2.图片格式SVG

3.实现原理

[3.1 H5标签引入svg图片](#3.1 H5标签引入svg图片)

[3.2 对进行加载和点击监听](#3.2 对进行加载和点击监听)


0.前言

ui设计了一张3D地图,需要进行地图地区中点击的交互,直接用echarts地图实现效果没设计图那么好,所以搜了下,利用canvas绘制比较好实现,但是ui不好导出canvas数据,只能提供svg格式的图片,试了下,SVG格式图片也能实现。

1.效果图

监听地图中各部分区域,输出对应区域

2.图片格式SVG

首先是ui提供svg格式的图片,看一下图片格式,应该是每个区域对应不同path,里面的id或者属性都可以自定义设置,例如给data-xxx属性之类,用于区分path。

3.实现原理

3.1 H5标签<object>引入svg图片

  • 基本语法:
html 复制代码
<object id="map" style="opacity: 1;" data="map.svg" type="image/svg+xml" width="1920" height="1080"></object>
  • 属性说明:
  1. type :必须设置为"image/svg+xml",表明引入的是SVG格式

  2. data:指定SVG文件的路径(相对路径或绝对路径)

  3. width/height:设置SVG的显示尺寸(单位可以是px、em或百分比)

3.2 对<object>进行加载和点击监听

javascript 复制代码
// 获取嵌入在HTML中的SVG对象,这里假设其ID为'map'
const obj = document.getElementById('map');

// 为SVG对象添加load事件监听器,确保SVG完全加载后再进行操作
obj.addEventListener('load', function() {
    // 通过contentDocument属性获取内嵌SVG的文档对象
    const svgDoc = obj.contentDocument;
    
    // 使用querySelectorAll选择SVG中所有的path元素
    // 这些path通常代表地图中的各个区域
    const paths = svgDoc.querySelectorAll('path');

    // 遍历所有找到的path元素
    paths.forEach(path => {
        // 为每个path元素设置鼠标悬停样式为手型,表示可点击
        path.style.cursor = 'pointer';
        
        // 为每个path添加点击事件监听器
        path.addEventListener('click', function(e) {
            // 获取被点击path元素的id属性,这个id通常对应区域名称
            const regionName = this.getAttribute('id');
            
            // 在控制台输出被点击区域的名称
            console.log('点击的区域是:', regionName);
            
            // 实际应用中,这里可以添加更多交互逻辑,比如:
            // 1. 高亮显示选中的区域
            // 2. 显示该区域的详细信息
            // 3. 触发相关的数据请求
        });
    });
});
  • svgDoc内容

paths内容

仅仅提供一种思路,毕竟svg图的格式中path划分因人而异,刚好ui能提供分地区的path图,可以实现地图点击交互的效果。

相关推荐
JarvanMo20 小时前
Flutter 的内存是怎么回事儿,简单给你讲明白——它给那些Widget分配和释放内存的机制
前端
烟袅20 小时前
🎯 `:nth-child` vs `:nth-of-type`:CSS 伪类的“兄弟之争”
前端·css
一水鉴天20 小时前
整体设计 全面梳理复盘之30 Transformer 九宫格三层架构 Designer 全部功能定稿(初稿)之2
前端·人工智能
有一棵树20 小时前
初级 Vue 前端开发者的命名与代码规范指南
前端
VcB之殇20 小时前
【three.js】实现玻璃材质时,出现黑色/白色像素噪点
前端·three.js
moeyui70520 小时前
Python文件编码读取和处理整理知识点
开发语言·前端·python
IT_陈寒20 小时前
WeaveFox 全栈创作体验:从想法到完整应用的零距离
前端·后端·程序员
pixle020 小时前
从零学习Node.js框架Koa 【一】 Koa 初探从环境搭建到第一个应用程序
前端·node.js·web·koa.js·web全栈·node服务端框架
抹茶生活20 小时前
CSS浮动样式
前端·css
匀泪20 小时前
CE(Linux的例行性工作)
前端·chrome