var html = '<div>dom</div>', body.innerHTML=html;
和 var div = document.createElement('div'), txt = document.createTextNode('dom'); div.appendChild(txt);
哪种方式好?
关于代码的优化,有时候要针对不同的浏览器。 上边innerHTML和appendChild哪个好呢?
在ie下,appendChild略胜
于innerHTML。 在chrome等webkit核的浏览器下, innerHTML优胜
于appendChild。下边我们来用在线测试来说明一下:(JS性能测试工具推荐:jsperf)
IE下的测试:
Chrome下的测试:
测试结果:
ie
下两者相差0.004s
,可以忽略不计。chrome
下两者相差0.868s
。 innerHTML 完胜 appendChild/createElement
总结:尽量少用createElement/apprendChild 这都是ie的东东。
我想自己测试一下,请猛击:http://jsperf.com/createelement-vs-innerhtml