DOM离线化

本文探讨了DOM离线化的三种方法,包括利用display控制元素显隐,使用createDocumentFragment批量处理DOM操作,以及创建节点副本进行操作后再替换,这些策略旨在减少页面回流和重绘,提升页面性能。

1.使用display控制显隐,临时将要操作的元素从文档流中脱离,然后再恢复它

	let el = document.getElementById('el');
	el.style.display = 'none';
	// 对 el 进行操作...
	el.style.display = 'block'

2.使用 createDocumentFragment,创建文档片段,操作后一次性把文档片段添加到文档流中(缓存批量化dom操作)。

	let fragment = document.createDocumentFragment()
	// 在 fragment 上进行一系列操作...
	document.getElementById('el').appendChild(fragment)

3.创建节点副本,在副本上进行操作,最后进行替换。

	let el = document.getElementById('el');
	let clone = el.cloneNode(true);
	// 对 clone 节点进行操作...
	el.parentNode.replaceChild(clone, el);

上面所述也是渲染层面的一种优化策略,减少页面的回流重绘。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值