웹 프론트엔드 JS 튜토리얼 @defer 및 지연 로딩으로 각도 성능 향상

@defer 및 지연 로딩으로 각도 성능 향상

Aug 06, 2024 am 04:26 AM

소개

Angular의 새로운 @defer 기능은 특히 지연 로딩 및 렌더링 최적화에서 성능을 향상하기 위한 프레임워크 개선 사항의 일부입니다. @defer 기능과 @placeholder 및 @loading 블록에 대한 간략한 개요는 다음과 같습니다.

@defer 개요

목적

  • @defer 기능은 필요할 때까지 애플리케이션 구성 요소나 일부의 로드 및 렌더링을 지연하도록 설계되었습니다. 이를 통해 애플리케이션의 초기 로드 시간을 크게 개선하고 사용자 경험을 향상할 수 있습니다.

용법

  • @defer는 구성 요소나 템플릿의 일부에 적용되어 느리게 로드되어야 함을 나타낼 수 있습니다. 이는 사용자가 처음 페이지를 방문할 때 즉시 표시되지 않거나 필요하지 않은 대규모 애플리케이션이나 애플리케이션 섹션에 특히 유용할 수 있습니다.

통사론

  • @defer를 사용하는 구문은 간단하며 Angular의 기존 템플릿 구문과 완벽하게 통합됩니다. 사용 방법에 대한 예는 다음과 같습니다.
  @defer {
  <large-component />
  }
로그인 후 복사

장점

  • 성능 최적화: 애플리케이션의 특정 부분 로드를 지연함으로써 초기 로드 시간을 줄여 더 빠르고 응답성이 뛰어난 사용자 경험을 제공할 수 있습니다.
  • 리소스 관리: 리소스는 필요한 경우에만 활용되므로 구성 요소 로드를 연기하면 더 나은 리소스 관리에 도움이 됩니다.
  • 사용자 경험: 중요한 콘텐츠를 먼저 로드하고 덜 중요한 콘텐츠는 필요할 때까지 연기하여 사용자 경험을 향상합니다.

Angular 생태계와의 통합

  • @defer 기능은 다른 Angular 기능 및 도구와 잘 통합되므로 개발자는 지연 로딩, 변경 감지 전략 및 기타 성능 최적화 기술을 응집력 있는 방식으로 활용할 수 있습니다.

미래 전망

  • Angular가 계속 발전함에 따라 @defer 기능이 더욱 향상되고 최적화될 가능성이 높습니다. 개발자는 애플리케이션의 일부가 로드되고 렌더링되는 방법과 시기를 보다 세밀하게 제어할 수 있습니다.

@defer 및 IntersectionObserver

내부적으로 @defer는 IntersectionObserver API를 사용합니다. 이 API를 사용하면 대상 요소와 상위 요소 또는 최상위 문서의 뷰포트 교차점의 변경 사항을 관찰할 수 있습니다. 구성 요소가 뷰포트에 진입하려고 할 때까지 구성 요소 로드를 연기하면 사용자가 볼 수 없는 리소스 로드를 방지하여 대역폭과 처리 능력을 절약할 수 있습니다.

IntersectionObserver의 다른 이점

초기 로드 시간 개선: 필요할 때까지 구성 요소를 연기하면 애플리케이션의 가장 중요한 부분만 처음에 로드됩니다. 이렇게 하면 초기 로드 시간이 줄어들고 애플리케이션의 인지된 성능이 향상되어 더 빠르고 반응성이 좋아집니다. Angular는 연기된 구성 요소에 대해 별도의 번들을 생성하므로 기본 번들의 크기도 줄어듭니다.

향상된 사용자 경험: 콘텐츠가 표시되기 직전에 콘텐츠를 로드하면 사용자에게 더욱 원활하고 원활한 경험을 보장할 수 있습니다. 이 기술은 사용자가 스크롤할 때 콘텐츠를 로드하면 애플리케이션이 느려지는 것을 방지할 수 있는 긴 스크롤 페이지에 특히 유용할 수 있습니다.

저전력 장치의 성능 향상: 처리 능력이 제한되어 있거나 네트워크 연결이 느린 장치는 지연 로딩을 통해 상당한 이점을 얻을 수 있습니다. 필요한 구성 요소만 로드함으로써 이러한 장치는 애플리케이션을 보다 효율적으로 처리할 수 있어 다양한 장치의 사용자에게 더 나은 경험을 제공할 수 있습니다.

옵션 없이 @defer 사용

다음은 Angular 애플리케이션에서 @defer를 사용하는 방법을 보여주는 예입니다. 먼저 이미지를 로드하는 구성요소를 만듭니다. 독립 실행형 구성 요소를 사용하는 것은 @defer의 요구 사항입니다.

import { Component } from "@angular/core";

@Component({
  selector: "app-images",
  standalone: true,
  template: `<div style="display: flex; flex-direction: column;">
    @for(image of list; track image) {
    <img [src]="image" width="600" height="400" />
    }
  </div> `,
})
export class ImagesComponent {
  list = Array(5).fill("https://placehold.co/600x400");
}
로그인 후 복사

그리고 여기서는 옵션 없이 @defer를 사용하고 있습니다.

<h1>Angular Defer Sample Application</h1>
@defer () {
<app-images></app-images>
}
로그인 후 복사

이제 생성된 번들을 보면 이미지 구성 요소에 자체 청크가 있음을 알 수 있습니다.

Boosting Angular Performance with @defer and Lazy Loading

네트워크 탭에서 페이지가 로드되면 이 번들이 이제 런타임에 로드되는 것을 볼 수 있습니다.

Boosting Angular Performance with @defer and Lazy Loading

옵션과 함께 @defer 사용

사용자 경험을 향상하기 위해 여러 가지 옵션을 사용할 수 있습니다. 이 섹션에서는 그 중 일부를 살펴보겠습니다.

Using @placeholder

By default, the defer block will render the content when it is visible in the viewport. However, there can be delays, for example, when the components are making HTTP requests. In those scenarios, we can use the @placeholder option. The content used for the placeholder is not lazy loaded. The content in the @placeholder is shown first until the @defer block's contents are ready to render. The placeholder itself comes with an optional argument called minimum. This allows you to set the time to display the content.

Here is how this would look:

<h1>Angular Defer Sample Application</h1>
@defer () {
<app-images></app-images>
} @placeholder (minimum 500ms) {
<p>Loading Images</p>
}
로그인 후 복사

And here is how this looks:

Boosting Angular Performance with @defer and Lazy Loading

Using @loading

The @loading block is used to display some content while the content defined in the @defer block is still loading or has started to load. This is different from the @placeholder block, which will appear before the loading starts. This block comes with two optional arguments, after and minimum. Similar to the @placeholder argument, the minimum argument is used to set the time to display the content. The second argument, after, is used to define the waiting time before showing the @loading content.

Here is how this would look:

<h1>Angular Defer Sample Application</h1>
@defer () {
<app-images></app-images>
} @loading (after 1s; minimum 500ms) {
<p>Loading Images</p>
}
로그인 후 복사

While you may not see this properly in the animated GIF, we are telling the block to wait at least 1 second before displaying the @loading content and show it for at least 500 ms.

Boosting Angular Performance with @defer and Lazy Loading

Conclusion

The @defer feature in Angular is a powerful tool for enhancing performance and user experience by delaying the loading of components until they are needed. By integrating this feature with options like @placeholder and @loading, developers can create more efficient and responsive applications. As Angular continues to evolve, features like @defer will play a crucial role in optimizing resource management and improving application performance across various devices and network conditions.

위 내용은 @defer 및 지연 로딩으로 각도 성능 향상의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? 프론트 엔드 열 용지 영수증에 대한 차량 코드 인쇄를 만나면 어떻게해야합니까? Apr 04, 2025 pm 02:42 PM

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

Demystifying JavaScript : 그것이하는 일과 중요한 이유 Demystifying JavaScript : 그것이하는 일과 중요한 이유 Apr 09, 2025 am 12:07 AM

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

Shiseido의 공식 웹 사이트와 같은 시차 스크롤 및 요소 애니메이션 효과를 달성하는 방법은 무엇입니까?
또는:
Shiseido의 공식 웹 사이트와 같은 페이지 스크롤과 함께 애니메이션 효과를 어떻게 달성 할 수 있습니까? Shiseido의 공식 웹 사이트와 같은 시차 스크롤 및 요소 애니메이션 효과를 달성하는 방법은 무엇입니까? 또는: Shiseido의 공식 웹 사이트와 같은 페이지 스크롤과 함께 애니메이션 효과를 어떻게 달성 할 수 있습니까? Apr 04, 2025 pm 05:36 PM

이 기사에서 시차 스크롤 및 요소 애니메이션 효과 실현에 대한 토론은 Shiseido 공식 웹 사이트 (https://www.shiseido.co.jp/sb/wonderland/)와 유사하게 달성하는 방법을 살펴볼 것입니다.

JavaScript는 배우기가 어렵습니까? JavaScript는 배우기가 어렵습니까? Apr 03, 2025 am 12:20 AM

JavaScript를 배우는 것은 어렵지 않지만 어려운 일입니다. 1) 변수, 데이터 유형, 기능 등과 같은 기본 개념을 이해합니다. 2) 마스터 비동기 프로그래밍 및 이벤트 루프를 통해이를 구현하십시오. 3) DOM 운영을 사용하고 비동기 요청을 처리합니다. 4) 일반적인 실수를 피하고 디버깅 기술을 사용하십시오. 5) 성능을 최적화하고 모범 사례를 따르십시오.

JavaScript의 진화 : 현재 동향과 미래 전망 JavaScript의 진화 : 현재 동향과 미래 전망 Apr 10, 2025 am 09:33 AM

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? JavaScript를 사용하여 동일한 ID와 동일한 ID로 배열 요소를 하나의 객체로 병합하는 방법은 무엇입니까? Apr 04, 2025 pm 05:09 PM

동일한 ID로 배열 요소를 JavaScript의 하나의 객체로 병합하는 방법은 무엇입니까? 데이터를 처리 할 때 종종 동일한 ID를 가질 필요가 있습니다 ...

Zustand 비동기 작동 : Usestore가 얻은 최신 상태를 보장하는 방법은 무엇입니까? Zustand 비동기 작동 : Usestore가 얻은 최신 상태를 보장하는 방법은 무엇입니까? Apr 04, 2025 pm 02:09 PM

zustand 비동기 작업의 데이터 업데이트 문제. Zustand State Management Library를 사용할 때는 종종 비동기 작업이시기 적절하게 발생하는 데이터 업데이트 문제가 발생합니다. � ...

See all articles