사이트의 가장 중요한 측면 중 하나는 로딩 속도입니다. 사용자는 브레이크 없이 즉시 사진을 받고 싶어하며, 이를 제공할 수 없으면 다른 곳에서 정보를 찾기 위해 오랫동안 주저하지 않을 것입니다. 이 기사에서는 웹사이트 로딩 시간을 단축할 수 있는 5가지 방법에 대해 설명합니다.

1. YSlow를 사용하여 페이지 로드 시간 추적

페이지를 로드하는 데 걸리는 시간을 알면 문제 영역을 식별할 수 있습니다. 또한 기능을 사용하여 상황을 수정하려는 또 다른 인센티브를 제공합니다.

시작하기 전에 YSlow를 아직 설치하지 않았다면 설치해야 합니다. YSlow는 모질라 파이어 폭스이 페이지에서 찾을 수 있습니다:

이제 사이트를 열어보자. 거의 동일한 데이터가 있다고 가정해 보겠습니다(브라우저의 새 탭에서 이 사이트를 열면 됨).

브라우저의 오른쪽 하단에는 아이콘이 있는 특수 패널이 있습니다(그림 1 참조). 이 패널에서 조금 더 멀리 페이지가 로드된 후 'YSlow' 옆에 숫자가 표시됩니다. 이 숫자는 이 페이지가 브라우저에 로드되는 시간(초)입니다. 우리는 이 숫자를 가능한 작게 하기를 원합니다.

가장 일반적인 "브레이크"는 다음 개체 또는 작업입니다.

  • 너무 많은 HTTP 요청
  • 압축되지 않은 JavaScript 파일
  • 그래픽 파일에 대한 헤더 만료 시간 없음

몇 분 안에 이에 대해 자세히 살펴보겠습니다.

이 시스템에 익숙해지려면 여러 사이트를 방문하여 로딩 시간을 확인하십시오. Google, Facebook 및 가장 자주 방문하는 몇 가지 즐겨찾는 블로그/웹사이트를 테스트할 수 있습니다. JavaScript 파일과 이미지는 속도에 가장 큰 영향을 미치는 파일입니다.

우리는 YSlow를 최대한 사용합니다.

페이지 로드 시간을 계산하는 YSlow 외에도 주어진 확장또한 구멍을 패치할 수 있도록 사이트 로딩을 최적화하기 위해 수정해야 할 사항에 대한 광범위한 정보를 제공합니다.

이러한 정보를 보려면 성능 탭을 클릭하십시오. 사이트를 크롤링한 후 YSlow는 페이지 성능을 특징짓는 전체 점수를 제공합니다.

CDN(콘텐츠 전달 네트워크)을 사용하여 정보에 대한 액세스를 가속화할 수 있습니다. CDN은 대규모 사이트에 가장 적합합니다. 여러 서버에 정보를 배포하는 데 사용됩니다. 다른 부분들평화. 이렇게 하면 개인 라우터를 거치지 않도록 적절한 서버(사용자와 가장 가까운 서버)에서 정보가 다운로드됩니다. YSlow는 CDN 요청도 추적합니다.

그러나 사람들은 일반적으로 CDN을 사용하지 않습니다(매우 비쌉니다).

오류 유형 분류

이제 위에서 언급한 확장에 있는 각 항목을 살펴보겠습니다. 아래에서 귀하의 페이지를 평가하는 방법과 최대 성능을 달성하기 위해 문제를 처리하는 방법에 대한 요약을 찾을 수 있습니다.

가능한 한 적은 수의 HTTP 요청 만들기: 브라우저가 서버에 요청을 보낼 때 HTTP 요청이 발생합니다. 클라이언트 측과 서버 측(Ajax 및 기타 유사한 기술)에서 스크립트, CSS 파일, 이미지 및 비동기 요청을 연결할 때도 동일한 일이 발생할 수 있습니다. 그러나 시스템 성능과 관련하여 유사한 요청페이지에서 발생합니다. 한 가지 솔루션은 캐싱을 사용하여 클라이언트 시스템이 스크립트, CSS 및 이미지를 더 빠르게 로드할 수 있도록 하는 것입니다.

Expires 헤더 추가: 페이지 로드의 80%가 스크립트, 사진 및 CSS 파일 다운로드에 집중됩니다. 대부분의 경우 이러한 사항은 사용자 컴퓨터에서 변경되지 않습니다. .htaccess 파일에 코드를 추가하면 사용자의 로컬 컴퓨터에 중복 파일을 캐시할 수 있습니다(이 작업을 수행하는 방법은 나중에 설명하겠습니다).

Gzip 구성 요소: Gzip을 적용하거나 JS 파일, 이미지, HTML 문서, CSS 파일 등 사용자가 축소된 크기로 정보를 다운로드할 수 있으므로 페이지 로딩 속도가 크게 빨라집니다. 또한 이렇게 하면 서버의 공간이 절약되지만 데이터 압축을 풀면 응답 속도가 느려질 수 있으며 사용자의 브라우저에 직접적으로 의존합니다.

페이지 상단에 CSS 배치: CSS 연결을 페이지 상단에 배치하면 먼저 로드되고 이미지와 스크립트는 나중에 로드됨을 의미합니다.

페이지 하단에 JS 배치: 이제 CSS 파일이 상단에서 로드되므로 닫는 태그 바로 앞에 JS 스크립트를 배치할 차례입니다. 이렇게 하면 페이지를 렌더링한 다음 필요한 스크립트를 포함할 수 있습니다.

CSS 표현 피하기: 개인적으로 CSS 표현(동적 속성이라고도 함)을 사용한 적이 없습니다. 이러한 표현식은 CSS의 기본 IE 프로그래밍 개념(예: 조건부 표현식)입니다. IE8 및 다른 모든 버전에서 사용되는 기술은 더 이상 지원되지 않으므로 어떤 경우에도 이 CSS 표현식 작성과 연결해야 합니다. PHP는 예를 들어 임의의 숫자, 시간 또는 사용자의 브라우저와 같은 일부 조건에 따라 다른 CSS 스타일을 로드하는 등의 목적에 더 적합합니다.

JS와 CSS를 별도의 파일에 작성: 스크립트를 JS에 넣고 CSS 스타일브라우저는 별도의 파일에 파일을 쉽게 캐시할 수 있으므로 향후 페이지를 더 빠르게 로드할 수 있습니다.

DNS 조회 시간 단축: 사용자가 브라우저 표시줄에 사이트 이름을 입력하면 사이트가 위치한 IP 주소의 DNS 조회가 즉시 시작됩니다. 사이트에 포함된 외부 소스가 많을수록 DNS 조회에 더 많은 시간이 소요됩니다. 일반적으로 이러한 검색 중 하나는 60-100밀리초 동안 지속됩니다.

JS 축소: gzip으로 압축하는 것 외에도 JavaScript 파일을 축소하면 불필요한 공백, 탭 및 큰 파일 크기를 추가하는 기타 특수 문자를 제거하여 스크립트를 가볍게 할 수 있습니다. 파일이 작을수록 페이지 로드 속도가 빨라집니다. JSMIN 도구를 사용하여 JavaScript 파일을 축소할 수 있습니다.

리디렉션 방지: JS, HTML 또는 PHP에서 리디렉션을 수행하는 위치는 중요하지 않습니다. 어느 쪽이든 브라우저는 로드하는 데 시간이 걸리는 빈 페이지 헤더를 수신합니다. 따라서 피할 수 있는 리디렉션을 사용하지 마십시오.

중복 스크립트 로드 방지: 브라우저가 스크립트를 두 번 이상 로드하면 페이지 로드에 상당한 영향을 미칩니다. 여기서 수학은 어렵지 않습니다. 같은 파일을 많이 다운로드할수록 더 긴 로딩페이지. 스크립트를 검토하고 jQuery를 2~3번 호출하지 않는지 확인하십시오. JS 스크립트에도 동일하게 적용됩니다.

글쎄요... 충분하다고 생각합니다. 이제 페이지 로딩 속도를 높이는 다른 기술을 살펴보기 전에 YSlow의 다음 탭으로 이동해 보겠습니다.

구성 요소 탭에서는 다운로드 속도를 향상시키기 위해 얼마나 많은 노력을 기울여야 하는지 결정할 수 있습니다. 여기에서 각 파일의 무게와 다운로드하는 데 걸리는 시간에 대한 정보를 찾을 수 있습니다. 또한 어떤 파일이 gzip으로 압축되고 있는지, 응답 시간, 파일이 사용자 컴퓨터에 캐시되었는지 여부, 캐시 자체가 종료되는 시간을 확인할 수 있습니다. 이 정보는 사이트의 문제를 평가할 때 유용할 수 있으며, 무엇이 문제인지, 최적화해야 하는 부분을 알게 됩니다.

그리고 마지막으로 다음으로 넘어가겠습니다. 마지막 탭통계 탭. 여기에서 일반 파일과 캐시된 파일에 대한 모든 HTTP 요청에 대한 정보를 찾을 수 있습니다. 빈 캐시 값은 페이지를 렌더링하기 위해 이러한 파일을 로드해야 함을 나타냅니다. 차례로 Primed Cache는 사용자의 브라우저에서 이미 캐시된 파일입니다. 즉, 다운로드할 필요가 없습니다.

2. CSS 스프라이트를 사용하여 HTTP 요청 줄이기

CSS 스프라이트는 아마도 Tesla가 전기를 발명한 이후로 인류가 생각해 낸 가장 중요한 것입니다. 실제로 그렇게 말했습니다.

글쎄, 아마도 가장 멋진 것은 아니지만 여전히.

CSS 스프라이트는 이미지 다운로드에 대한 HTTP 요청 수를 줄여 페이지 로딩 속도를 크게 향상시키는 데 도움이 될 수 있습니다.

CSS 스프라이트가 일반적으로 사용자 인터페이스에서 사용하는 방법에 대해 설명하는 많은 자습서를 찾을 수 있습니다.

이제 YouTube에서 CSS 스프라이트를 사용하는 방법을 간단히 살펴보겠습니다. 그들이 사용하는 스프라이트는 다음과 같습니다.

YouTube는 이 파일을 다소 독창적인 방식으로 사용합니다. 스프라이트 클래스의 배경으로 로드합니다. 요소를 선택해야 할 때 초기 위치가 선택됩니다. CSS 도움말 background-position 속성을 선택한 다음 높이와 너비를 적용합니다.

비슷한 것을 시도해 봅시다. YouTube에서 동일한 이미지를 실험해 보겠습니다.

아래 예에서는 화면에 YouTube 로고를 표시하고 있습니다. 동일한 스프라이트 클래스와 동일한 이미지를 사용하여 마우스 오버 시 변경되는 이미지를 만들 수 있습니다.

따라서 이 이미지를 사용하여 단일 HTTP 요청에 대한 모든 연결을 줄일 수 있습니다. 글쎄, 효과는 무엇입니까?

또 다른 장점 CSS 스프라이트:hover 의사 클래스를 적용할 때 이미지가 잠시 동안 사라지지 않을 것입니다. CSS 사용스프라이트.

3. 처음에는 CSS 파일을 로드하고 끝에는 JavaScript를 로드합니다.

일부 사이트의 경우 HTTP 요청 수를 줄이면 기능이 중단될 수 있습니다. 페이지 로딩 속도를 높이는 또 다른 방법은 모든 JavaScript 파일 연결을 문서 끝에 넣는 것입니다.

또한 주목할 가치가 있습니다.

  1. body 태그 시작 직전 섹션에 CSS 파일을 로드합니다.
  2. 닫는 본문 태그 바로 앞에 JavaScript를 포함하십시오.

우리의 조언을 따르면 JavaScript가 백그라운드에서 로드되는 동안 사용자가 사이트를 감상할 수 있습니다.

참고: 이동을 원하지 않는 경우 자바스크립트 태그, 기능이 떨어질까 두렵기 때문에 defer 속성을 사용하는 것이 좋습니다. 다음과 같이 적용하십시오.