So I\'ve seen three ways to add html/DOM elements to a page. I\'m curious what the pros and cons are for each of them.
1 - Traditional JavaScript
If you already have a template element that you want to copy then by all means use clone().
But if you want to create an element from scratch then there's basically two methods which I think you alluded to:
First if either of the methods is more intuitive or easier to write for you, I'd recommend just doing that.
Otherwise benefits of using the latter is that it is cleaner if the element has many children. For example, try to make a table row with 6 columns, each with a different class using the first method. Your code will be much longer than if you used the second method.
As far as performance goes this is a good guide http://andrew.hedges.name/experiments/innerhtml/ but the short answer is for most cases the differences are quite negligible. A good guide for performance in general as well is: http://www.artzstudio.com/2009/04/jquery-performance-rules/. The 6th tip has to do with DOM manipulation.