<object> 标签中的 usemap 属性用于将嵌入的对象(如图像)与一个 图像映射(image map) 关联起来。图像映射允许你在图像的特定区域定义可点击的链接,用户点击这些区域时会触发相应的操作。


什么是图像映射?

图像映射是一种将图像的特定区域与超链接关联的技术。它通过 <map> 标签定义,并使用 <area> 标签指定可点击区域的形状、坐标和链接目标。


usemap 属性的作用

usemap 属性将 <object> 嵌入的内容(通常是图像)与一个 <map> 元素关联起来。它的值是一个以 # 开头的 <map> 元素的 nameid


使用方法

  1. 定义图像映射(<map><area>

    使用 <map> 标签定义图像映射,并在其中使用 <area> 标签指定可点击区域的形状、坐标和链接目标。

  2. 关联图像映射(usemap

    <object> 标签中使用 usemap 属性,将其与 <map> 标签关联。


示例

以下是一个完整的示例,展示如何使用 <object>usemap 实现图像映射:

<object data="example.png" type="image/png" usemap="#imagemap" width="500" height="300">
您的浏览器不支持显示此图像。
</object> <map name="imagemap">
<!-- 定义一个矩形区域 -->
<area shape="rect" coords="0,0,100,100" href="https://example.com/page1" alt="Page 1"> <!-- 定义一个圆形区域 -->
<area shape="circle" coords="200,150,50" href="https://example.com/page2" alt="Page 2"> <!-- 定义一个多边形区域 -->
<area shape="poly" coords="300,200,350,250,400,200" href="https://example.com/page3" alt="Page 3">
</map>

代码解析

  1. <object> 标签

    • data="example.png":嵌入的图像文件。
    • type="image/png":指定图像的MIME类型。
    • usemap="#imagemap":将图像与名为 imagemap<map> 元素关联。
  2. <map> 标签

    • name="imagemap":定义图像映射的名称,与 usemap 属性关联。
  3. <area> 标签

    • shape:定义区域的形状,可以是 rect(矩形)、circle(圆形)或 poly(多边形)。
    • coords:定义区域的坐标。
      • 对于 rectcoords="x1,y1,x2,y2",表示矩形的左上角和右下角坐标。
      • 对于 circlecoords="x,y,radius",表示圆心坐标和半径。
      • 对于 polycoords="x1,y1,x2,y2,x3,y3,...",表示多边形的各个顶点坐标。
    • href:定义点击区域后跳转的链接。
    • alt:为区域提供替代文本,用于无障碍访问。

适用场景

  • 图像热点:在图像中定义多个可点击区域,例如地图、产品图等。
  • 交互式图像:为用户提供更丰富的交互体验,例如点击图像的不同部分跳转到不同页面。

注意事项

  1. 坐标计算

    区域的坐标是基于图像的像素值,需要精确计算。可以使用图像编辑工具(如Photoshop)获取坐标。

  2. 无障碍访问

    为每个 <area> 添加 alt 属性,确保屏幕阅读器能够正确读取。

  3. 兼容性

    <object><map> 在现代浏览器中兼容性良好,但在某些旧版浏览器中可能存在问题。


总结

<object> 标签中的 usemap 属性用于将嵌入的内容(如图像)与图像映射关联,从而实现图像中特定区域的可点击功能。通过 <map><area> 标签,可以灵活定义多个可点击区域,为用户提供丰富的交互体验。

object中的usemap是什么-HTML的更多相关文章

  1. APEX:对object中数据进行简单处理?

    在Salesforce中,常常要对各种数据进行处理,已满足业务逻辑.本篇文章会介绍如何实现从object获取数据,然后将取得的数据进行一系列简单处理. 第一步:SongName__c 是一个新建的ob ...

  2. 使用第三方工具覆写Object中方法

    我们在实际开发中,经常需要覆写Object中的equals,hashcode,toString方法,其实编写这些代码并不是很难,但很枯燥和乏味. 下面推荐Google的Guava jar包来覆写上面的 ...

  3. java锁与监视器概念 为什么wait、notify、notifyAll定义在Object中 多线程中篇(九)

    在Java中,与线程通信相关的几个方法,是定义在Object中的,大家都知道Object是Java中所有类的超类 在Java中,所有的类都是Object,借助于一个统一的形式Object,显然在有些处 ...

  4. Object 中 equals()使用

    详细看: https://www.cnblogs.com/naihuangbao/p/9445027.html 1. ==是判断两个变量或实例是不是指向同一个内存空间equals是判断两个变量或实例所 ...

  5. 为什么notify(), wait()等函数定义在Object中,而不是Thread中

    Object中的wait(), notify()等函数,和synchronized一样,会对“对象的同步锁”进行操作. wait()会使“当前线程”等待,因为线程进入等待状态,所以线程应该释放它锁持有 ...

  6. JS如何遍历Object中的所有属性?

    JS如何遍历Object中的所有属性? var params = ""; for(var i in baseParams){ params += "&" ...

  7. Object中的方法以及对象相等的判定

    看图说话 Object有以下几个方法 getClass() final类型,主要是用来获得运行时的类型 hashCode() 返回该对象的哈希码值,方法是为了提高哈希表(例如 java.util.Ha ...

  8. Object中的clone方法

      Java中对象的创建 clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的复制对象,首先要分配一个和源对象同样大小的空间,在这个空间中创建一个新的对象 ...

  9. eclipse环境Dynamic web module version 3.1版本的进步,简化Dynamic web object 中Servlet类的配置,不用web.xml配置<Servlet>

    eclipse环境Dynamic web module version 3.1版本之前,Dynamic web object 中Servlet类的配置,要在web.xml 配置<Servlet& ...

  10. Object中的wait,notify,notifyAll基本使用(转)

    让线程停止运行/睡眠的方法只有两个:Thread.sleep()或者obj.wait() 记住obj.nofity()并不能停止线程运行,因为notify虽然释放了锁,但依然会急促执行完synchro ...

随机推荐

  1. PHP 安装启用imagick(解决 word press可选的模组imagick未被安装或已被禁用)

    本教程仅适用Windows Servier IIS网站服务器. 我的博客使用IIS搭建,相比Linux,相关的教程格外少.因此让以后的小伙伴也能马上解决问题,分享此方法. 首先需要下载php对应版本的 ...

  2. Solution Set - “伸手向着拉格朗日点作别”

    目录 0.「UR #9」「UOJ #133」电路手动分析 1.「UR #9」「UOJ #134」App 管理器 2.「UR #10」「UOJ #152」汉诺塔 3.「UNR #2」「UOJ #312」 ...

  3. Kotlin:【继承】:继承、函数重载、类型检测、as类型转换、智能类型转换、Kotlin层次

  4. VLDB来啦!企业上云“搭子”天翼云TeleDB数据库有话说

    近日,VLDB 2024(International Conference on Very Large Data Bases)在广州隆重举行,全球数据库领域顶尖学者汇聚一堂,围绕数据库行业前沿议题展开 ...

  5. IDEA新建多模块maven项目

    1.new =>projetc=>maven=>,新建完成后删除src目录     2.增加java模块 例:robots2-common 项目根目录就是[robots2-paren ...

  6. CSP 初赛要点复习

    位运算 逻辑与.按位与之类的东西是不同的!"逻辑"的是判断两个数都不为 \(0\),"按位"的是判断两个数的每一个二进制位与的结果,是不同的.其他运算也类似. ...

  7. 天线增益是什么意思?DBI越大越好吗?

    作者: 技象物联网/ 行业百科 / 无线通信, 通信系统 / 2023年6月23日 11:58:21 天线增益是指天线在某个方向上相对于一个理想点源天线所辐射的功率密度的增益.换句话说,天线增益是天线 ...

  8. MySQL Q&A - [02] windows上MySQL的安装路径变更之后无法启动MySQL服务

    参考:https://blog.csdn.net/weixin_45271005/article/details/130091868 Step1:首先,变更之前,需要保证MySQL服务是停止运行的 S ...

  9. 大数据之路Week10_day05 (Redis的安装与简单命令使用)

    Redis 支持单机版和集群,下面的步骤是单机版安装步骤 redis3.0.0版本的安装包百度云链接: 链接:https://pan.baidu.com/s/1mb_SdU5hHlrmUkWN7Drx ...

  10. 机器学习 | 强化学习(3) | 无模型预测(Model-Free Prediction)

    无模型预测(Model-Free Prediction) 无模型预测概论 上一节课<通过DP求解>可以解决一个已知的马尔科夫决策过程 本节课 实践无模型预测 解决或者估计一个未知马尔科夫决 ...