> 웹 프론트엔드 > JS 튜토리얼 > 프로파일 링 페이지는 내비게이션 타이밍 API로로드됩니다

프로파일 링 페이지는 내비게이션 타이밍 API로로드됩니다

Lisa Kudrow
풀어 주다: 2025-02-25 18:04:13
원래의
273명이 탐색했습니다.
웹 페이지 로딩 성능의 심층 분석 : 내비게이션 타이밍에 대한 자세한 설명 api

Profiling Page Loads with the Navigation Timing API 코어 포인트

탐색 타이밍 API는 DNS 조회, TCP 연결 설정, 페이지 리디렉션, DOM 구성 시간 및 기타 표시기를 포함하여 웹 페이지로드 중에 자세한 타이밍 정보를 제공합니다. 브라우저에 내장되어 있으며 추가 오버 헤드가 없습니다.

객체에 정의됩니다.
  • API는 페이지 로딩 프로세스 중에 많은 이정표 이벤트의 타임 스탬프를 기록하며, 각 이벤트는
  • 객체의 속성으로 저장됩니다. 이벤트가 발생하지 않으면 그 값은 0입니다. API는 또한 사용자가 특정 페이지에 액세스하는 방법을 결정하는 인터페이스를 정의합니다.
  • 탐색 타이밍 API는 AJAX 호출과 함께 사용하여 실제 사용자 데이터를 서버에 다시보고 할 수 있습니다. 이를 통해 개발자는 페이지가 실제 환경에서 어떻게 작동하는지 이해할 수 있습니다. 이 데이터는 또한 페이지로드 프로세스의 시각적 차트를 만드는 데 사용될 수 있습니다. window.performance.timing
  • 웹 페이지 로딩 속도는 사용자 경험에 영향을 미치는 주요 요소 중 하나입니다. 로딩 속도가 느리면 사용자를 실망시키고 이탈 할 수 있습니다. 그러나 사용자의 브라우저, 네트워크 조건, 서버로드 및 애플리케이션 코드 등과 같은 전체 로딩 시간에 영향을 미치기 때문에 많은 요인이 느린 로딩의 원인을 문제 해결하는 것은 일반적으로 쉽지 않습니다. 다행히도 내비게이션 타이밍 API는이 문제를 쉽게 해결하는 데 도움이 될 수 있습니다.
  • 과거에는 개발자 가이 영역에서 수집 된 데이터에 대한 액세스가 매우 제한적이었습니다. 많은 개발자들이 오랫동안 JavaScript의 window.performance.timing 객체를 사용하여 성능 데이터를 수집했습니다. 예를 들어, 다음 코드는 페이지로드 이벤트 핸들러 호출 후 타임 스탬프를 비교하여 로딩 시간을 측정합니다.
  • 이 방법에는 몇 가지 문제가 있습니다. 첫째, javaScript의 시간 정확도는 두 번째로,
  • 객체는 셋째,
  • 객체는 코드를 측정 할 수 있습니다 브라우저에서 실행 한 후 실행 시간은 서버, 네트워크 등과 같은 페이지로드 프로세스에 대한 데이터를 제공 할 수 없습니다.
내비게이션 타이밍 API 데뷔

보다 정확하고 포괄적 인 페이지로드 데이터를 제공하기 위해 W3C는 내비게이션 타이밍 API를 제안했습니다. 이 API는 페이지로드하는 동안보다 자세한 타이밍 정보를 제공합니다. 객체와 달리 내비게이션 타이밍 API는 DNS 조회, TCP 연결 설정, 페이지 리디렉션, DOM 빌드 시간 및 기타 다양한 메트릭과 관련된 측정 데이터를 제공합니다. 내비게이션 타이밍도 브라우저에 내장되어있어 추가 오버 헤드가 발생하지 않습니다.

Date 탐지 브라우저 지원

var start = new Date();

window.addEventListener("load", function() {
  var elapsed = (new Date()).getTime() - start.getTime();
}, false);
로그인 후 복사
로그인 후 복사

위 내용은 프로파일 링 페이지는 내비게이션 타이밍 API로로드됩니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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