> 웹 프론트엔드 > 프런트엔드 Q&A > CSS가 캐시되지 않는 이유는 무엇입니까?

CSS가 캐시되지 않는 이유는 무엇입니까?

PHPz
풀어 주다: 2023-04-23 15:07:44
원래의
664명이 탐색했습니다.

CSS(Cascading Style Sheets)는 프런트 엔드 개발의 가장 기본적인 기술 중 하나로 웹 사이트 페이지를 아름답게 만들고 사용자 경험을 최적화하는 데 자주 사용됩니다. 그러나 웹사이트 개발자는 CSS 스타일을 디버깅할 때 CSS 파일이 캐시되지 않는 문제에 자주 직면합니다.

CSS 캐싱이란 무엇인가요?

웹사이트를 방문하면 서버는 HTML, CSS, JavaScript, 이미지 및 기타 파일과 같은 일부 정적 리소스를 브라우저로 보냅니다. 페이지 로드 속도와 사용자 경험을 개선하기 위해 브라우저는 이러한 파일을 캐시하여 다음에 방문할 때 동일한 페이지가 더 빠르게 로드되도록 합니다. 이 캐싱 메커니즘을 HTTP 캐싱이라고 합니다.

사용자가 처음으로 페이지를 방문하면 브라우저는 모든 정적 리소스를 다운로드하여 로컬 캐시에 저장합니다. 사용자가 페이지를 다시 방문하면 브라우저는 파일을 다시 다운로드하지 않고도 캐시에서 직접 읽을 수 있습니다. 이렇게 하면 페이지 로딩 속도가 향상되고 서버 부하가 줄어듭니다.

CSS 파일이 캐시되지 않는 이유는 무엇인가요?

그러나 개발자가 CSS 스타일을 수정할 때 브라우저가 페이지의 스타일을 업데이트하지 않지만 여전히 이전에 캐시된 파일을 로드하는 경우가 있습니다. 이는 CSS 파일이 캐시되지 않는 문제입니다.

이 문제의 원인은 HTTP 캐싱 메커니즘이 작동하는 방식 때문입니다. 브라우저가 정적 리소스를 요청하면 리소스의 Etag 값을 서버에 반환하는 요청 헤더 If-Modified-Since를 가져옵니다. 서버는 이 요청 헤더를 확인합니다. 브라우저의 로컬 캐시가 만료되지 않은 경우 서버는 304 상태 코드를 반환하여 로컬 캐시에서 파일을 얻을 수 있음을 나타냅니다. 따라서 개발자가 CSS 스타일을 업데이트하더라도 브라우저가 여전히 이전 요청 헤더가 포함된 파일을 요청하면 서버는 여전히 304 상태 코드를 반환하므로 브라우저는 CSS 스타일을 업데이트하지 않습니다.

CSS 파일이 캐시되지 않는 문제를 해결하는 방법은 무엇입니까?

  1. 브라우저 캐시 지우기

개발자는 브라우저 캐시를 지워 CSS 파일이 업데이트되지 않는 문제를 해결할 수 있습니다. Chrome 브라우저에서는 주소 표시줄에 chrome://settings/clearBrowserData를 입력하여 데이터 지우기 페이지를 열고 브라우저 캐시 및 쿠키 데이터 지우기를 선택한 후 "데이터 지우기" 버튼을 클릭할 수 있습니다.

  1. URL에 버전 번호 추가

개발자는 브라우저가 최신 파일을 얻을 수 있도록 CSS 파일의 URL에 버전 번호를 추가할 수 있습니다. 예를 들어 ../style.css?v=1.0은 스타일을 수정한 후 버전 번호를 다른 숫자나 타임스탬프로 변경합니다. 브라우저는 이 파일을 새 파일로 간주하여 스타일을 업데이트합니다. 이 방법은 파일 링크를 수동으로 수정해야 하며 소규모 프로젝트에 적합합니다.

  1. Cache-Control 및 Pragma 설정

개발자는 서버 측 HTTP 응답 헤더에 Cache-Control 및 Pragma를 설정하여 브라우저가 리소스를 캐시하는 시기와 방법을 제어할 수 있습니다. 예를 들어 Cache-Control을 no-cache 또는 max-age=0으로 설정하고 Pragma를 no-cache로 설정하면 브라우저가 리소스를 캐시하지 않고 각 요청이 최신 버전의 파일을 반환한다는 의미입니다. 이 방법은 대규모 프로젝트와 트래픽이 많은 웹사이트에 적합합니다.

결론

CSS 파일이 캐시되지 않는 문제는 프런트 엔드 개발에서 흔히 발생하는 문제이지만, 브라우저 캐시를 지우고 버전 번호를 사용하고 Cache-Control 및 Pragma를 설정하면 사용자는 이 문제를 해결하고 웹 사이트를 개선할 수 있습니다. 로딩 속도와 사용자 경험.

위 내용은 CSS가 캐시되지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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