锚标签和图像映射

时间:2010-01-07 06:29:43

标签: javascript jquery html css imagemap

如何将锚标记与图像映射相关联?

假设我将鼠标悬停在锚标记上,它应该选择图像上的映射区域。

http://myffi.biz/这样的东西。这是闪存,但可以使用图像映射吗?您将鼠标悬停在链接上,它应该选择图像上的映射区域。

这可能吗?我希望我很清楚

1 个答案:

答案 0 :(得分:4)

是的,它可以在没有Flash的情况下完成,但您根本不需要图像映射。只需要一个悬停事件淡入地图上的正确图像,这很容易用jQuery做。这样的事情可能有用:

<ul class="region">
    <li><a href="#" id="europe">Europe</a></li>
    <li><a href="#" id="asia">Asia</a></li>
    <li><a href="#" id="africa">Africa</a></li>
    <li><a href="#" id="australia">Australia</a></li>
</ul>
<div id="region-map">
    <div id="region-overlay"></div>
</div>

在CSS中,您将region-map定义为没有选择区域的背景,region-overlay选择了不同的区域。

#region-map, #region-overlay {
    width: 640px;
    height: 320px;
}

#region-map {
    background: url(map-base.jpg) 0 0 no-repeat;
}

#region-overlay.europe {
    background: url(map-europe.jpg) 0 0 no-repeat;
}

#region-overlay.asia {
    background: url(map-asia.jpg) 0 0 no-repeat;
}

#region-overlay.africa {
    background: url(map-africa.jpg) 0 0 no-repeat;
}

#region-overlay.australia {
    background: url(map-australia.jpg) 0 0 no-repeat;
}

需要jQuery代码:

$(function() {
    $('ul.region a').hover(function() {
        // Get the current region
        var region = $(this).attr('id');
        // Hide the current overlay, change it's map and change it back.
        $('#region-overlay').fadeOut(200, function() {
            $(this).attr('class', region).fadeIn(200);
        });
    }, function() {
        // Hide the overlay
        $('#region-overlay').fadeOut(200);
    });
});

这不是完美的,但应该让你开始。

可以在以下网址找到一个工作示例:

  

http://www.ulmanen.fi/stuff/hovermap/