Christian Heilmann

You are currently browsing the Christian Heilmann blog archives for April, 2006.

Archive for April, 2006

innerHTML vs. DOM = pot noodles vs. real cooking

Tuesday, April 18th, 2006

Following four days of AFN (Away From Network – I did use a keyboard though), I realised that dugg me and AJAXian once again linked me. Well, not me but the From DHTML to DOM Scripting article.
Notice the title: from DHTML to DOM. Not “why innerHTML is rubbish and you should not use it, never, really, don’t, never ever!”

I also realised that AJAXian had the unfortunate wording in their post that I might have meant that with the article and the comments on the AJAXian post were an interesting read indeed.

However, digging deeper (oh dear), I found that this is an no-barriers-handbags-out-geek-fight topic at the moment as many AJAX enthusiasts and heavy load web application developers (the applications are heavy load, not the developers) rightfully like innerHTML and consider it a necessary and good solution for a re-occuring problem.

Jeremy Keith started it, daring to call innerHTML proprietary in the painless code creation with DOM builder post at the DOM scripting task force blog.
Jonathan Snook responded quickly and wondered what’s wrong with innerHTML.
We all know that Jeremy had been in a painful love/hate relationship with innerHTML for a long time, as he outed himself in December talking about his innerHTML dilemma.
He is not the only one with this problem, as Ryan Campbell of Particletree also considered different methods than innerHTML in April calling it Changing the DOM.

This is all well and good, but is it really that much of a problem?

My “I like to chime in but I really just want to keep the fight going and not get involved myself as I forgot my handbag” award goes to Dustin Diaz who kept the comments closed on his blog entry on the subject called innerHTML and DOM Methods. So why post at all then? Why not just comment on Jeremy’s blog?

I liked the quote:

Well, for what it’s worth. It’s about the user. innerHTML is plain and simply faster. Yes, it’s non-standard, but so is xmlHttpRequest. Sure, I know the W3 is developing a working draft on xmlHttpRequest… I say, let’s standardize innerHTML. Not to mention, it would be easy. Everyone already knows how it works, it’s simple to use. It’s fast. It’s already supported across major browsers. Hey, just so we feel better, why not call it innerXML. That way it’s future compatible when xml becomes more of a standard and better supported.

This is exactly the problem with innerHTML – it is not innerXML. It is a browser/web/html only property, and the DOM is not only for browsers, web and HTML. You can use JavaScript and the DOM to convert XML, you can even script applications with it (check the Adobe site for great Illustrator and Adobe Bridge examples), and the idea is not to keep DOM scripting to the browser or even to HTML as a means of structure. I especially chuckled at the notion that XML will be supported in the future. I know the idea was supporting XML in browsers, but talking about web standards and considering XML a technology of the future is simply missing the mark.

So, here are my ideas about this subject:

innerHTML is pot noodles – Anyone can use it quickly, you put the kettle on and after the water boiled and you let it rest for a minute or so and then it is feeding time. It is:

  • very fast and convenient
  • cheap and easy to prepare
  • well known and available in a lot of stores

The problems are:

  • You have no clue what is in the pot noodles
  • You have no way of telling someone how to make own pot noodles when there is no shop around their area that stores them.

DOM scripting and using the DOM methods to create a real XML construct instead of a string of HTML is cooking your own pasta sauce:

  • You know the ingredients and you measure them properly before applying them
  • It is harder and takes longer to prepare, but the outcome is normally
  • While you cook you learn about different spices, tricks to prepare the ingredients and mix and match them to make the perfect sauce
  • You follow a recipe or invent your own – but you do follow a structured method of creating it
  • You can explain how to create the sauce to someone on the phone step by step

So by all means: Use innerHTML when speed or ease of use is an issue, but don’t forget that the DOM offers a lot more than just changing HTML documents in a browser.

How to say good-bye to your company after five years

Thursday, April 13th, 2006

Nerd style

time to leave in Web2.0 confusion

Thursday, April 13th, 2006 is a place where people post photoshop-manipulated photos and animations. Unlike Worth1000 where the main idea is skill and immaculate photo manipulation b3ta thrives on novelty, skill, crudeness and, yes, immaturity. The joke of the picture is more important than the technical quality. Chances are you found a lot of b3ta pictures as “funny attachments” in your inbox over the years.

Every week there is a new challenge what pictures should be about and this week they picked “Imaginary Applications for Web 2.0”. The results are quite funny, although not up to the normal quality of b3ta as the contributors are utterly confused as to what Web2.0 might be about.

Warning: Some of the entries of the competition are not work safe as they might be deemed inappropriate, political incorrect and show crudely drawn comic genitalia. I warned you.

And the winner of cheekiest SPAM attempt is

Tuesday, April 11th, 2006

This just blew my mind:

Attempt to spam my comments by pleading for help how to get rid of a spam adware infection

I would believe that it could be a person really asking for help to get rid of a spyware/trojan infection if he hadn’t used a naughty site as his own URL.

Anyways, why should I know how to get rid of it. I never surf naughty parts of the internet, honestly!

Making AJAX navigation optional

Monday, April 10th, 2006

I just put up a proof of concept for the AJAX chapter of my book. For years I have ranted about DHTML multi level menus simply assuming that every user wants to have every page in the sitemap as an item in the navigation.

My idea was to make the enhanced navigation optional and allowing the user to decide initially.
Check out the example:

It uses PHP to only provide a chunk of the full navigation automatically replacing the current link with a strong when JS is unavailable and when JavaScript is available it offers a link that turns the navigation into a multi level tree menu loading the main page content via XHR.

What do you think? Helpful? I think it is a lot less obtrusive than a lot of fancy menu systems out there while offering the same options.