登录  /  注册
首页 > web前端 > css教程 > 正文
css:border-collapse属性与table里td边框opacity透明度的详解
黄舟
发布: 2017-06-30 09:41:21
原创
6583人浏览过

一、原来不是bug

年前遇到此现象,在Chrome浏览器下,起初,我还以为是Chrome浏览器的bug.

今日原型重现,在各个现代浏览器下一测,乖乖隆地咚,都是一个尿性,看来是规范使然,不是bug啊!但是,由于现象实在诡异,到目前也想不通是个怎么回事,故在这里演示并询问在座的小伙伴们,为什么会有此现象?

现象描述
一个普普通通的table,设置了border-collapse:collapse,合并表格的边框,这很正常,也很常见。

我们给元素设置opacity透明度值,例如0.1,则元素应该透明度就变成10%,包括边框、背景色等,这也符合我们的理解,很正常。

但是,两者搞在一起,就出现了诡异解析。表格元素如<td>边框透明度似乎是100%透明度减去<td>定义的透明度值的差值(opacity:1除外)!也就是<td>设置透明度10%,则边框却是90%的透明度;而<td>设置透明度90%,边框却是10%的透明度。

文字描述太苍白,我们还是看实例吧(IE10+, FireFox, Chrome均可)~

默认我们的<tbody>(便于演示,<td>效果一样)opacity值为1,于是,我们看到了一片和谐的效果:

1665.png

但是,我们拖动Demo页面上的range控件,修改<tbody>的透明度opacity属性值,结果,你会发现,<tbody>透明度为90%的时候,我了个擦,边框直接透明度(肉眼看上去)就是10%透明度的样子。

Chrome浏览器下,最后一行单元格的边框似乎不受opacity的影响,如下截图:

1666.png

而FireFox浏览器下,则是所有边框都会差异半透明化:

1667.png

然后,我们继续拖动,差不多10%透明度的样子时候,此时,文字是规规矩矩透明了,但是,边框的颜色却反而愈发地清晰起来!!

1668.png

1669.png

IE浏览器也不甘落后:

1670.png

二、造成的问题

我想使用CSS3实现一个淡入淡出的动画,那效果,诡异如坐针毡!

三、如何避免此尴尬

一般实际开发时候,我们使用的table边框是单边框,不是那种格子之类,此时,我们可以:
只对低版本的IE浏览器使用border-collapse:collapse;对于高级浏览器,删除border-collapse:collapse声明,或者使用separate重置,然后使用border-spacing:0去除单元格见你不想要的空白。

于是,透明度就符合正常认知地渲染了!

以上就是css:border-collapse属性与table里td边框opacity透明度的详解的详细内容,更多请关注php中文网其它相关文章!

相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学