100%点击区的滑动门

作者:blank 来源:怿飞's Blog 时间:2007-06-14 22:00:00 

BLOG地址:http://www.planabc.net/article.asp?id=107

学习标准的朋友,一般都会在学习的过程中接触到CSS滑动门技术,或许大家也都看过这篇文章《CSS中的滑动门技术》,如果你还没接触过或还没看过上文或有点忘记内容,也没关系,可以点击上面的文章链接,先了解或温习一遍。

在《CSS中的滑动门技术》一文中的滑动门例子,大家仔细实验,或许已经发现,链接区有9像素的盲点无法点击,而且在IE下,只能点击文字部分大小,不能点击整个按钮区块。而我们或许期望的是整个按钮区块都可以点击,并且不允许有盲点存在。

那我们又该如何去实现呢?下面我们一起来探讨一些解决方法:

首先为了方便我们先把《CSS中的滑动门技术》中的代码移过来:

XHTML部分


<div id="header">
  <ul>
    <li><a href="#">Home</a></li>
    <li id="current"><a href="#">News</a></li>
    <li><a href="#">Products</a></li>
    <li><a href="#">About</a></li>
    <li><a href="#">Contact</a></li>
  </ul>
</div>


CSS部分


#header {
  float:left;
  width:100%;
  background:#DAE0D2 url("bg.gif") repeat-x bottom;
  font-size:93%;
  line-height:normal;
}
#header ul {
  margin:0;
  padding:10px 10px 0;
  list-style:none;
}
#header li {
  float:left;
  background:url("left.gif") no-repeat left top;
  margin:0;
  padding:0 0 0 9px;
}
#header a {
  float:left;
  display:block;
  background:url("right.gif") no-repeat right top;
  padding:5px 15px 4px 6px;
  text-decoration:none;
  font-weight:bold;
  color:#765;
}
/* Commented Backslash Hack
   hides rule from IE5-Mac \*/
#header a {float:none;}
/* End IE5-Mac hack */
#header a:hover {
  color:#333;
}
#header #current {
  background-image:url("left_on.gif");
}
#header #current a {
  background-image:url("right_on.gif");
  color:#333;
  padding-bottom:5px;
}


查看效果

运行代码框


方法一:使用相对位置负外边距

为了消除滑动门的9px的盲点区域,设置li的外边距为9px(9px为left图片的宽度大小),li的背景为right图片,不重复,右上对齐。


#header li {
  background:url("right.gif") no-repeat right top;
  margin-left:9px;
}


然后让a向左移动9px,覆盖掉盲点区域,如何移动呢?可对a使用相对位置(position:relative;),用负值移动9px(left:-9px;)。由于li的宽度等于a的宽度,所以当a位置相对左移9px时,li的右边就会多出9px的盲区,如何解决呢?我们使用a的负外边距来解决(margin-right:-9px;)。


#header a {
  position:relative;
  left:-9px;
  margin-right:-9px;
}


设置left图片为a的背景,不重复,左上对齐,并设置文字的内边距,注意现在a的区域为整个按钮的区域,所以padding-left和padding-right的值都应为15px。


#header a {
  background:url("left.gif") no-repeat left top;
  padding:5px 15px 4px;
}


另注意一个细节:在IE中链接的区域为文字区域而不是按钮区域,而在其他对标准支持比较好的浏览器里是按钮区域。为了解决这个问题,我们给IE中的a指定个固定宽度来触发IE的layout(可以选用.1em,1px,1%等值),但这样一来a在其他对标准支持比较好的浏览器里则会识别这个宽度,我们选用对标准支持比较好的浏览器识别而IE6不识别的子选择器来让a的宽度变为auto。


#header a {width:.1em;}
#header > ul a {width:auto;}


相对应的,对于current选择器里的图片位置也要做一点调整:


#header #current {
  background-image:url("right_on.gif");
}
#header #current a {
  background-image:url("left_on.gif");
  padding-bottom:5px;
}


标签:CSS,滑动门
0
投稿

猜你喜欢

  • Go语言实现配置热加载的方法分享

    2024-02-07 04:02:47
  • 利用Pytorch实现获取特征图的方法详解

    2023-09-11 16:16:02
  • python实现淘宝秒杀聚划算抢购自动提醒源码

    2022-12-04 11:43:15
  • mysql 批处理文件出错后继续执行的实现方法

    2024-01-19 13:25:09
  • 如何利用 Python 绘制动态可视化图表

    2022-11-23 17:14:37
  • 解决Python2.7读写文件中的中文乱码问题

    2023-05-16 11:23:51
  • 关于Torch torchvision Python版本对应关系说明

    2021-06-17 09:13:52
  • python基于Node2Vec实现节点分类及其可视化示例详解

    2022-04-16 06:49:33
  • sql条件查询语句的简单实例

    2024-01-28 02:17:36
  • 浅谈Go语言的error类型

    2024-05-10 13:57:58
  • Python打开文件,将list、numpy数组内容写入txt文件中的方法

    2023-12-16 21:23:17
  • python中列表对象pop()方法的使用说明

    2021-10-25 09:45:40
  • Python标准库之typing的用法(类型标注)

    2021-09-27 01:25:24
  • Django DRF路由与扩展功能的实现

    2022-05-03 09:43:15
  • MySQL也能并发导入数据

    2010-03-25 10:38:00
  • JS图片懒加载的优点及实现原理

    2024-04-18 09:45:34
  • 详解Bagging算法的原理及Python实现

    2021-06-10 00:20:41
  • layer 刷新某个页面的实现方法

    2024-04-10 10:46:39
  • MySQL索引类型Normal、Unique和Full Text的讲解

    2024-01-20 09:56:19
  • python 字符串和整数的转换方法

    2023-10-11 02:31:42
  • asp之家 网络编程 m.aspxhome.com