> 웹 프론트엔드 > CSS 튜토리얼 > Mac용 Chrome에서 DOM 다시 그리기/새로 고침을 강제하는 방법은 무엇입니까?

Mac용 Chrome에서 DOM 다시 그리기/새로 고침을 강제하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-23 10:57:35
원래의
994명이 탐색했습니다.

How to Force a DOM Redraw/Refresh in Chrome for Mac?

Mac용 Chrome에서 강제 DOM 다시 그리기/새로 고침

Mac용 Chrome에서 유효한 HTML/CSS가 발견되면 요소가 잘못 렌더링되거나 별말씀을요. 브라우저 콘솔에서 DOM을 검사하면 일반적으로 다시 그리기가 트리거되지만 보다 자동화된 솔루션이 바람직합니다.

다음 JS 스니펫은 대부분의 브라우저 및 운영 체제에서 효과적으로 작동합니다.

el.style.cssText += ';-webkit-transform:rotateZ(0deg)'
el.offsetHeight
el.style.cssText += ';-webkit-transform:none'
로그인 후 복사

그러나 Mac용 Chrome은 offsetHeight에 의해 트리거된 다시 그리기를 우회합니다. 해결 방법은 setTimeout을 사용하여 요소의 테두리를 일시적으로 변경하고 강제로 다시 그리는 것입니다.

$(el).css("border", "solid 1px transparent");
setTimeout(function()
{
    $(el).css("border", "solid 0px transparent");
}, 1000);
로그인 후 복사

이 접근 방식은 번거롭고 눈에 띕니다. Mac용 Chrome에서 강제로 다시 그리기를 수행하는 더 효율적인 방법은 요소에 빈 텍스트 노드를 삽입하는 것입니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿