您的位置:首页 > 其它

在table中tr的display:block显示布局错乱问题

2016-09-21 14:01 399 查看
在前端页面展示需要通过判断来显示 标签内的东西,按照常理,对于某一单元行需要显示时,使用:display:block属性,不需要显示时使用display:none属性,而且这样做 在IE浏览器中显示正常,没有任何问题。

但是当用Firefox浏览时却出现了布局错乱的问题,然后通FireBug去看了下源码,调试下了,发现是display:block属性搞的鬼。

1、当表格为多列的情况下,属性为”display:block”行的内容宽度仅与第一列宽度相同,也就是说无论你使colspan的属性值为多少,剩余列的空间都不进行解析。

2、同一行反复的在”display:none;”与”display:block;”两个状态间切换时,表格的底部会持续的产生多余的空白空间以至于造成页面布局的扭曲。

解决方法:

1、用display:table-row属性来调试,发现者FireFox下正常了,但IE是不支持改属性的,怎么办呢?用JS来做判断,然后做兼容吧。

2、另外一个很简单也很可行的方法,就是用 display:’ ’ 这个属性dispaly后面不加任何的东西,很奇怪,这样就兼容了Firefox和IE了。具体原因有待牛人分析。

别答案:

1、每个html标签都有自己的默认display属性的,你把display设置成空的时候,浏览器应该是把元素给成默认的属性了,所以就兼容了所有的浏览器,可谓是无招胜有招啊!

2、不过,如果tr的display:none是在外部引入的css文件中设置的话,在ie7脚本中用display:”方法是没有用的
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  tr display block