当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > ie6和ie7中的链接图片点不中问题讨论

CSS样式表
关于CSS控制DIV水平居中问题
CSS:相同元素不同结构重复定义的问题
关于DIV CSS和XHTML CSS的理解
CSS教程:简单理解em
CSS教程:导致一些问题的overflow
CSS常用属性的代码简化实例
CSS教程:总结清除浮动的方法
网页设计中典型的header代码结构
CSS初学者常犯错误汇总
CSS网页布局:div水平居中的各种方法
CSS Div网页布局中的结构与表现
CSS教程:简化CSS中属性的示例
CSS网页布局:div垂直居中的各种方法
acronym标记和abbr标记的不同之处
CSS编写的网页打开流畅相关知识与注意点
你知道CSS中长度单位pt、px、dpi的意思吗?
CSS页面布局中HTML结构化
CSS选择器的使用技巧
CSS教程:网页图片垂直居中的使用技巧
dl,dt,dd标记在网页中要充分利用

CSS样式表 中的 ie6和ie7中的链接图片点不中问题讨论


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-03   浏览: 54 ::
收藏到网摘: n/a

最近重新审视了一下块集元素和内联元素,不是混淆,而是重新想了一下新的东西,有时候在我们进行重构的时候,偶尔会为了实际需要而将内联元素强制显示为块集元素,在一般情况下,这个是不会出问题的,而且可以很轻松的通过标准,但是在某一些情况下,虽然验证工具可以放过我们,但是在ie6下面会出现解析不正确的问题,下面就简单跟大家分享一下这个问题。

有时候由于需要文字和图片同时获取到点击态,或者需要实现一些高难度的效果,就需要多标签来写结构,可能的结构会如下所示:

<div class="block">
    <a href="http://www.ruanchen.com"><span><img src="http://www.ruanchen.com/p-admin/images/webjx.png" alt="Raina" /></span></a>
</div>

在没有被赋予强大的CSS的时候,是可以正常点击的,但是当赋予需要的CSS的时候,在ie8一下就会出现图片区域点击不到的情况:

.block span{float:left;}

如果将span标签块集化:

.block span{float:left;dispaly:block;width:100px;height:100px;}

最终的结果依然不是不能点击到,但是图片区域以为的内容确可以正常点击。

而对于此,我的理解是这样的:

因为a标签本身就是一个内联元素标签,内联标签内正常情况只允许放置内联元素,放置块集元素本身语法就有问题,虽然表面上放置的span标签,但是我们又将其强制块集化,在某些浏览器下还是会解析错误,比如说ie6/7,所以这里针对链接的这种情况,出现的问题就是图片区域无法点击。

针对这种问题的解决方法:

保证在a标签中不要放置块集元素,或者强制块集元素,如果需要解决一些特殊效果,可以采取将这个强制元素跟a内置的img标签同级放置,这样也可以避免图片点击不到问题。