高性能JavaScript之浏览器中的DOM

文档对象模型(DOM)是一个独立于语言的,用于操作 XML 和 HTML 文档的程序接口。在浏览器中,通常会把 DOM 和 JavaScript 独立实现(放在两个不同的库中)。这对性能意味着什么?天生就慢!就像两座岛屿之间有座收费桥,每次交流都要交过桥费。并且,当我们要修改 HTML 中元素的时候更为昂贵,因为会涉及到 HTML 回流和重绘。

// 操作 DOM 元素
function addHTML() {
	for (var count = 0; count < 10000; count++) {
		document.getElementById('p').innerHTML += 'a';
	}
}
// 上述问题在于每次循环 p 元素都被访问两次:一次读取 innerHTML 值,一次修改它
// 可以修改为:
function addHTML() {
	var content = '';
	for(var count = 0; count < 10000; count++) {
		content += 'a';
	}
	document.getElementById('p').innerHTML = content;
}

总结:减少访问 DOM 的次数,把运算尽量放到 script 里面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值