前言
最近在看《高性能网站建设》,记录一下所学。
现在很多网站都是图片形式的导航,点击图片跳转到对应的链接。如果导航项目很多的话,图片的数量就会很多,每需要加载一张图片就会多一个HTTP请求。优化的方式之一就是使用图片地图
标签
图片地图要用到map和area标签
map标签用于客户端的图片映射;area标签指定映射区域。兼容性良好,可放心使用
栗子
<aside class="container">
<img src="src/img_map.png" alt="导航图片" usemap="#nav_test">
<map name="nav_test">
<area shape="rect" coords="0 0 300 110" href="https://www.so.com/" target="_blank" alt="360搜索">
<area shape="rect" coords="0 110 300 212" href="https://www.baidu.com/" target="_blank" alt="百度搜索">
</map>
</aside>
img的usename可指定所使用的映射,对应map的name属性
area的shape属性规定形状(default|rect|circle|poly);coords属性规定区域,不同的shape时,coords的格式也不一样(栗子中shape为矩形,coords就指定了矩形左上角和右下角的坐标,单位为px . ps:在html4的时候还可以是百分比,但是html5貌似只能是数值);href和target、alt就和a标签的一样
一张图片就对应了两个不同的链接,而只有一个http请求,减少了一个请求了。如果导航很多的情况下,减少的请求数量就会很可观。