CSS Image Maps—图像地图

作者:greengnn 时间:2014-07-23 21:58:49 

原文地址:http://frankmanno.com/ideas/css-imagemap-redux/

1.先说说图像地图是什么?

就是在一张图片上标记出有url的地方,当鼠标滑过的时候,给以像<a href="url" title="description words">links</a>这样的代码显示的
效果。

2.查看实例

Example 1      Example 2

3.方法

这是xhtml:

 <dl id="officeMap">
  <dt id="monitor">1. Monitor</dt>
  <dd id="monitorDef"><a href="#"><span>Here's my 17" Monitor.  I wish I had an LCD!</span></a></dd>
 </dl>

分析这段代码是必要的,因为他是结构,效果肯定是通过a标签的:hover,以及:hover span的定义实现的,怎样具体去实现效果呢?

1.)需要一张图片,那就给#officeMap一个背景图片office.jpg

dl#officeMap{
 margin: 0;
 padding: 0;
 background: transparent url(office.jpg) top left no-repeat;
 height: 262px;
 width: 350px;
 position: relative;
}

定义内部元素相对定位,不然怎样给map定位位置?

2.)下来是dt dd标签

dt{ margin: 0; padding: 0; position: absolute; font-size: 85%; display: none; }/*这个url的介绍,不用显示*/
dd{ margin: 0; padding: 0; position: absolute;  font-size: 85%; }/*定义绝对定位*/

3.)#monitorDef的定义,a:hover效果

dd#monitorDef{ top: 65px; left: 114px; }/*定义位置*/
dd#monitorDef a{ position: absolute; width: 73px; height: 69px; text-decoration: none; }
dd#monitorDef a span{ display: none; }
dd#monitorDef a:hover{ position: absolute; background: transparent url(office.jpg) -109px -317px no-repeat;
top: -10px; left: -5px; }/*背景图片滑动,参考滑动门技术(原理相似),span内容的定位*/

4.)下来是重点,span这个主要效果是怎么实现的?

dd#monitorDef a:hover span{
 display: block;
 text-indent: 0;
 vertical-align: top;
 color: #000;
 background-color: #F4F4F4;
 font-weight: bold;
 position: absolute;
 border: 1px solid #BCBCBC;
 bottom: 100%;
 margin: 0;
 padding: 5px;
 width: 250%;
}/*这里不需要解释*/

5.原作者认为,这个模型不是ideal(理想的),因为可能背景图片太费事,第二个模型是根据png图片透明原理(FireFox下)

CSS改进如下:

dd#monitorDef a{ position: absolute; width: 73px; height: 69px; text-decoration: none;
 background: transparent url(note.png) repeat;}
dd#monitorDef a:hover{ position: absolute; background: transparent url(office.jpg) -109px -317px no-repeat;
top: -10px; left: -5px; background: transparent url(http://www.blueidea.com/tech/web/2006/hover.png) repeat;}

这样就避免了,制作office.jpg那样麻烦的图片了,只要给a标签 加上背景图片就能区别出map的位置,但是只有firefox支持怎么行,我们
熟悉的IE怎么办?

filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='http://www.blueidea.com/tech/web/2006/hover.png',sizingMethod='scale');

作者是使用他来实现的,国内css研究者们已经翻译了这个技术

而我使用:filter:alpha(opacity=80);便解决了,都是CSS的filter,这个再研究,我也不太明白!

标签:
0
投稿

猜你喜欢

  • 超简单使用Python换脸实例

    2021-07-31 17:03:36
  • 在JavaScript中获取请求的URL参数

    2024-04-25 13:08:43
  • 基于python爬取有道翻译过程图解

    2021-11-03 23:57:27
  • ASP.NET Core基础之Main方法讲解

    2024-06-05 15:43:21
  • 互联网一家之言(一):叫用户为你买单

    2009-06-09 11:32:00
  • JavaScript中的this指向问题详解

    2024-04-28 09:46:58
  • pytorch索引查找 index_select的例子

    2023-09-12 20:45:05
  • python 下载文件的多种方法汇总

    2023-08-11 16:50:05
  • javascript new fun的执行过程

    2010-08-05 21:23:00
  • Python中sub()的用法说明

    2023-08-04 14:29:32
  • JavaScript数据结构中串的表示与应用实例

    2023-08-26 10:38:38
  • BootStrap 轮播插件(carousel)支持左右手势滑动的方法(三种)

    2024-04-18 09:39:33
  • Django模板继承与模板的导入实例详解

    2023-04-03 14:41:28
  • 获取SQL Server数据库元数据的几种方法

    2024-01-17 16:00:44
  • 对python3 Serial 串口助手的接收读取数据方法详解

    2023-05-31 17:39:01
  • asp模板解析类模块(支持if,function,loop及解析缓存)

    2008-08-11 13:06:00
  • Python configparser模块操作代码实例

    2021-11-05 18:48:08
  • 解析php获取字符串的编码格式的方法(函数)

    2023-10-02 22:26:49
  • MySQL索引的一些常见面试题大全(2022年)

    2024-01-13 00:17:30
  • SQL Server数据在不同数据库中的应用

    2008-12-24 15:34:00
  • asp之家 网络编程 m.aspxhome.com