Fixing PNG in IE6 by JavaScript

If you are a web developer and think that you can completely forget about the problems that IE6 has brought, then perhaps Microsoft and the users has disappointed you. One of the issues is IE6s inability to render transparent PNG files correctly. Let read this article, author will guide you how to overcome this problem with JavaScript completely.


Sampled by © JavaScriptBank.com

In 2009 you'd think (and hope) that we could completely forget the problems with Internet Explorer 6. One of the issues that has caused me a lot of hassle is IE6s inability to render transparent PNG files correctly.

There are various ways to deal with IE5.5/IE6s PNG problem. I have tried several different ways of handling this situation - from using TwinHelix method, right through to serving alternative image content for IE5.5/IE6 via conditional comments and alternative stylesheets.

I've found the problem with the TwinHelix method is page load time is affected quite significantly, then serving alternative content via alternative stylesheets is a time-consuming way to handle this problem.

As I tend to use JavaScript to control various style elements that go above-and-beyond the capabilities of CSS alone, I have decided to use JavaScript to fix PNGs.

The limitation of this solution is that users who disable JavaScript will see the unfixed PNG images on their page if they are using IE5.5/IE6. However, in terms of caching and overall page speed, the small level of users browsing without JavaScript is something that I would balance in favour of a cacheable JavaScript solution to the problem.

I have been using the excellent DD_belatedPNG fix from Diller Design. All credits go to Diller Design, and to find out more please check out their site.

This easy to use method works in the following way:

1. Download the DD_belatedPNG JavaScript file (Right click > Save As). Uncompressed / Compressed. Check for latest version here.

2. Call the JavaScript file within the head section of your page as follows:

<script src="http://www.whatever.com/path/to/file/DD_belated_PNG_0.0.8a.js" type="text/javascript"></script>

3. Create a blank JavaScript file in Note Pad or an equivalent text editor and place the following code into the file, then save the file as pngfix.js:

DD_belatedPNG.fix('.png_bg');

4. In the above code replace .png_bg with any ID or class that you have applied to the image in your HTML code or in your external stylesheet. For example, if you want to apply the fix to your logo, you might give your image the class logo. This would look like the following:

<img src="http://path/to/image/file/logo.png" width="100" height="50" class="logo" />

5. If we carry on the example in step four, you would adjust the pngfix.js file as follows:

DD_belatedPNG.fix('.logo');

Other classes can be added by separating each class with a comma (I.e. DD_belatedPNG.fix('.logo, .icon, img');).

6. Now call the pngfix.js file in the head of the page below the DD_belated_PNG_0.0.8a.js file as follows:

<script src="http://www.whatever.com/path/to/file/pngfix.js" type="text/javascript"></script>

7. In the head of the page you should have the following:

<script src="http://www.whatever.com/path/to/file/DD_belated_PNG_0.0.8a.js" type="text/javascript"></script> <script src="http://www.whatever.com/path/to/file/pngfix.js" type="text/javascript"></script>

8. Now we want all other browsers to ignore the PNG fix, so we wrap the two JavaScript files in conditional comments as follows:

<!--[if lte IE 6]> <script src="http://www.whatever.com/path/to/file/DD_belated_PNG_0.0.8a.js" type="text/javascript"></script> <script src="http://www.whatever.com/path/to/file/pngfix.js" type="text/javascript"></script> <![endif]-->

Now if you test your page in IE6, you should find transparent PNGs that you have specified in the pngfix.js file are rendered correctly.

Language
Translate this page to English Translate this page to French Translate this page to Vietnamese

Recent articles
Insights for Advanced Zooming and Panning in JavaScript Charts
How to open a car sharing service
Vue developer as a vital part of every software team
Vue.js developers: hire them, use them and get ahead of the competition
3 Reasons Why Java is so Popular
Migrate to Angular: why and how you should do it
The Possible Working Methods of Python Ideology
JavaScript Research Paper: 6 Writing Tips to Craft a Masterpiece
Learning How to Make Use of New Marketing Trends
5 Important Elements of an E-commerce Website


Top view articles
Adding JavaScript to WordPress Effectively with JavaScript Localization feature
Top 10 Beautiful Christmas Countdown Timers
Top 10 Best JavaScript eBooks that Beginners should Learn
65 Free JavaScript Photo Gallery Solutions
16 Free Code Syntax Highlighters by Javascript For Better Programming
Best Free Linux Web Programming Editors
Top 50 Most Addictive and Popular Facebook mini games
More 30 Excellent JavaScript/AJAX based Photo Galleries to Boost your Sites
Top 10 Free Web Chat box Plug-ins and Add-ons
The Ultimate JavaScript Tutorial in Web Design


Free JavaScript Tutorials & Articles
at www.JavaScriptBank.com