网络编程 
首页 > 网络编程 > 浏览文章

优化innerHTML操作(提高代码执行效率)

(编辑:jimmy 日期: 2025/5/13 浏览:3 次 )
例子:我们要实现的效果是当用户点击鼠标的时候,就在旧数据上追加若干新数据。
  如果使用标准DOM的话,完整代码如下:
复制代码 代码如下:
<html>
<head>
<title>test</title>
</head>
<body>
<div>
<p>data<p>
</div>
<script>
document.onmousedown = function() {
for (var i = 0; i < 10; i++) {
var p = document.createElement("p");
p.appendChild(document.createTextNode(Math.random()));
document.getElementsByTagName('div')[0].appendChild(p);
}
};
</script>
</body>
</html>

注:一旦结构比较复杂的话,标准DOM需要编写冗长的代码。
  如果使用innerHTML的话,部分代码如下:
复制代码 代码如下:
<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
document.getElementsByTagName('div')[0].innerHTML += html;
};
</script>

注:innerHTML没有标准DOM中的appendChild,所以使用了『+=』的方式,效率低下。
  我们可以结合使用innerHTML和标准DOM,这样二者的优点就兼得了,部分代码如下:
复制代码 代码如下:
<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
var temp = document.createElement("div");
temp.innerHTML = html;
while (temp.firstChild) {
document.getElementsByTagName('div')[0].appendChild(temp.firstChild);
}
};
</script>

注:创建一个元素,然后注入innerHTML,接着在元素上使用标准DOM操作。
  还不算完,Asynchronous innerHTML给出了更强悍的解决方法,部分代码如下:
复制代码 代码如下:
<script>
document.onmousedown = function() {
var html = "";
for (var i = 0; i < 10; i++) {
html += "<p>" + Math.random() + "<p>";
}
var temp = document.createElement('div');
temp.innerHTML = html;
var frag = document.createDocumentFragment();
(function() {
if (temp.firstChild) {
frag.appendChild(temp.firstChild);
setTimeout(arguments.callee, 0);
} else {
document.getElementsByTagName('div')[0].appendChild(frag);
}
})();
};
</script>

注:使用setTimeout防止堵塞浏览器,使用DocumentFragment减少渲染次数。
  另:代码在拼接字符串时还可以更快,详见:Fastest way to build an HTML string。
上一篇:jQuery设计思想完整篇
下一篇:js中将URL中的参数提取出来作为对象的实现代码
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap