CSS in Internet Explorer - Some lessons learned
I’ve spent the last few days working with CSS, and in particular trying to make a layout which works perfectly fine in Firefox work properly in Internet Explorer 6.
I’m far from an expert when it comes to this but I’ve picked up a few lessons from our attempts to get identical layouts in both browsers.
-
Internet Explorer seems to do some crazy stuff when it comes to padding and margins - we were often ending up with huge margins where we hadn’t even specified any. A useful approach pointed out by Josh was resetting the margin and padding for the whole page so that IE’s default padding was removed. Putting the following code in your style sheet will do this: ~css * {padding:0;margin:0} ~
-
Despite the fact that we start with IE and Firefox on an even keel, there were still differences in how they rendered some spacings that we tried to apply. I don’t think this is necessarily a good long term fix but it seems that if you start a property name with an underscore IE will respect it but Firefox will ignore it. This is known as the MSIE underscore hack, which describes it fairly accurately! We can therefore set up IE only CSS properties like this: ~css _margin: 0 0 2px 0; ~
-
One of the other problems we came across was the hidden text bug - sometimes when we refreshed the page text inside a floating div would just disappear until you selected it with the mouse when it would reappear. We found a couple of posts which explained that the problem was being caused by IE not correctly setting the element size for floating elements on the page. The other posts go into more detail, but the fix that worked for us involved forcing IE into layout mode by applying a small height to the element that was being hidden: ~css .visualIEFloatFix { height: 0.01%; } ~
I’m sure there will be further learnings on my CSS travels - I’ve been trying to find some resources which describe good patterns to use with CSS but I’ve only come across a book called Pro CSS and HTML Design Patterns so far.
Anyone know if this book is any good or if not what a better alternative is?
About the author
I'm currently working on short form content at ClickHouse. I publish short 5 minute videos showing how to solve data problems on YouTube @LearnDataWithMark. I previously worked on graph analytics at Neo4j, where I also co-authored the O'Reilly Graph Algorithms Book with Amy Hodler.