HTML 标签的 usemap 属性
usemap属性将图像(或对象)指定为图像映射(图像映射是具有可单击区域的图像)。
实例
客户器端图像映射:
<html>
<body>
<p>请点击图像上的星球,把它们放大。</p>
<img src="/images/eg_planets.jpg" border="0" usemap="#planetmap" alt="Planets">
<map name="planetmap" id="planetmap">
<area shape="circle" coords="180,139,14" href="/example/html/venus.html" target="_blank" alt="Venus">
<area shape="circle" coords="129,161,10" href="/example/html/mercur.html" target="_blank" alt="Mercury">
<area shape="rect" coords="0,0,110,260" href="/example/html/sun.html" target="_blank" alt="Sun">
</map>
<p><b>注释:</b>img 元素中的 "usemap" 属性引用 map 元素中的 "id" 或 "name" 属性(根据浏览器),所以我们同时向 map 元素添加了 "id" 和 "name" 属性。</p>
</body>
</html>
解释
上面这段源代码将一幅图像 planets.gif 映射为 3 个区域,当用户单击其中某一个区域时,将被链接到不同的文档中。
定义和用法
usemap属性将图像(或对象)指定为图像映射(图像映射是具有可单击区域的图像)。
usemap属性与<map>元素的名称或id属性关联,并在<img>和<map>之间创建关系。
注意:如果<img>元素是<a>或<button>元素的子体,则不能使用usemap属性。
HTML 4.01 与 HTML5 之间的差异
没有。
浏览器支持
所有浏览器都支持 usemap 属性。
语法
<img usemap="value">
<object usemap="value">
属性值
值 | 描述 |
---|---|
#mapname | # + 要使用的 <map> 元素的 name 或 id 属性 |
延伸阅读:详解 usemap 属性
usemap 属性提供了一种“客户端”的图像映射机制,有效地消除了服务器端对鼠标坐标的处理,以及由此带来的网络延迟问题。通过特殊的 <map> 和 <area> 标签,HTML 创作者可以提供一个描述 usemap 图像中超链接敏感区域坐标的映射,这个映射同时包含相应的超链接 URL。usemap 属性的值是一个 URL,它指向特殊的 <map> 区域。用户计算机上的浏览器将把鼠标在图像上单击时的坐标转换成特定的行为,包括加载和显示另外一个文档。
我们举例说明一下,下面这段源代码将一个 100x100 像素的图像 map.gif 映射为 4 个区域,当用户单击其中某一个区域时,将被链接到不同的文档中。请注意,在这个 <img> 标签中,我们已经有效地包含了对 ismap 图像映射的处理功能,这样,那些使用不具有 usemap 处理功能的浏览器用户,就可以通过另外一中途径,即服务器端机制来处理图像映射:
<a href="/example/map">
<img src="/images/map.gif" ismap="ismap" usemap="#map" />
</a>
<map name="map">
<area coords="0,0,49,49" href="link1.html">
<area coords="50,0,99,49" href="link2.html">
<area coords="0,50,49,99" href="link3.html">
<area coords="50,50,99,99" href="link4.html">
</map>
ismap 属性和 usemap 属性的应用差异
地图就是很好地应用 ismap 和 usemap 属性的一个示例,例如,在浏览一家全国范围的大公司网页时,用户可能会在地图上单击他们所居住的城市,以获得附近地区零售店的地址和电话号码等。
usemap 客户端处理图像映射的好处是,它不要求有服务器或特殊的服务器软件,与 ismap 机制不同,它可以用在非 web (无网络)环境中,例如在本地的文件或者 CD-ROM 中使用。