如何在Chrome for Mac 上強制重繪DOM
在Web 開發中,有時需要強制瀏覽器重繪或刷新DOM DOMOM>
在Web 開發中,有時需要強制瀏覽器重繪或刷新DOM DOMOM (文檔物件模型)。雖然有多種方法適用於大多數瀏覽器,但 Mac 版 Chrome 提出了獨特的挑戰。 修改未使用的 CSS 屬性、查詢元素尺寸,然後恢復更改的標準技術不再適用Mac 版 Chrome。此行為是由於在檢索 offsetHeight 屬性時防止重繪的最佳化所致。 要克服此限制,可以採用一種更具侵入性的方法:$(el).css("border", "solid 1px transparent"); setTimeout(function() { $(el).css("border", "solid 0px transparent"); }, 1000);
$('#parentOfElementToBeRedrawn').hide().show(0);
document.getElementById('parentOfElementToBeRedrawn').style.display = 'none'; document.getElementById('parentOfElementToBeRedrawn').style.display = 'block';
var forceRedraw = function(element){ if (!element) { return; } var n = document.createTextNode(' '); var disp = element.style.display; // don't worry about previous display style element.appendChild(n); element.style.display = 'none'; setTimeout(function(){ element.style.display = disp; n.parentNode.removeChild(n); },20); // you can play with this timeout to make it as short as possible }
以上是如何在 Mac 版 Chrome 強制重繪 DOM?的詳細內容。更多資訊請關注PHP中文網其他相關文章!