HTML页面中DOM更新时机的奇怪问题

本文描述了一个关于在不同浏览器上实现一致的DOM更新效果的问题。具体表现为“正在加载”提示在Firefox上可见,但在IE和Safari上缺失,直到远程数据加载完成。文章探讨了可能的原因,并提供了一个通过setTimeout来解决此问题的有效方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在开发中遇到一个奇怪的问题,这个问题的场景是比较简单的,在一个DOM节点中首先要显示的是一条“正在加载”的消息,然后从远程获取一些数据,并显示在此DOM中。在Firefox下面,“正在加载”的消息能够正常显示,之后从远程获取的数据也能正常显示出来;但是在IE和Safari上面,“正在加载”的消息不能显示出来,DOM节点的内容先是空白的,只有等远程的数据拿到之后,才有内容显示出来。

 

后来进过分析,认为可能的原因是获取远程数据时包含了同步调用,导致DOM节点的内容通过innerHTML设置“正在加载”这条消息的时候并没有更新显示。不过只有Firefox上面正常,也觉得挺奇怪的。

 

解决的办法是通过window.setTimeout(func, 0)来把获取数据的方法人为的押后,这样让浏览器可以有机会去即时更新DOM,并显示“正在加载”的消息。这样一修改之后,在Firefox,IE和Safari上面都没有问题了。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值