> 웹 프론트엔드 > CSS 튜토리얼 > 동적으로 로드된 CSS 스타일시트가 일부 브라우저에서만 작동하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

동적으로 로드된 CSS 스타일시트가 일부 브라우저에서만 작동하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Linda Hamilton
풀어 주다: 2024-11-25 14:30:14
원래의
706명이 탐색했습니다.

Why Do My Dynamically Loaded CSS Stylesheets Only Work in Some Browsers (and How Can I Fix It)?

IE에서 동적으로 CSS 스타일시트 로드

동적 CSS 로드는 페이지 로드 대기 시간을 최소화하는 반응형 디자인을 만드는 데 매우 유용한 것으로 입증되는 경우가 많습니다. 그러나 이 기술을 사용할 때 사용자는 자신의 스타일이 선택한 일부 브라우저에만 적용되는 경우가 많습니다.

아래 예에서 CSS 스타일은 Firefox 및 Google Chrome에서는 성공적으로 로드되지만 인터넷에서는 로드되지 않습니다. Explorer(IE).

var head = document.getElementsByTagName('head')[0];
$(document.createElement('link'))
    .attr({ type: 'text/css', href: '../../mz/mz.css', rel: 'stylesheet' })
    .appendTo(head);
로그인 후 복사

해결책:

차이점은 다음과 같은 방식에서 발생합니다. IE는 스타일시트 처리를 처리합니다. 다른 브라우저와 달리 IE는 내장된 스타일 엔진이 페이지에 로드된 모든 스타일을 구문 분석한 후에만 스타일시트 첨부를 허용합니다. 이를 방지하기 위해 우리는 로딩 프로세스 중에 스타일시트를 안정적으로 추가하는 document.createStyleSheet(url) 메소드를 활용합니다.

url = 'style.css';
if (document.createStyleSheet)
{
    document.createStyleSheet(url);
}
else
{
    $('<link rel="stylesheet" type="text/css" href="' + url + '" />').appendTo('head'); 
}
로그인 후 복사

이 메소드를 통합함으로써 CSS가 모든 브라우저에 적용되도록 보장합니다. Internet Explorer의 고유한 로딩 동작을 사용하는 경우에도 마찬가지입니다.

위 내용은 동적으로 로드된 CSS 스타일시트가 일부 브라우저에서만 작동하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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