0

0

使用 @defer 和延迟加载提升角度性能

WBOY

WBOY

发布时间:2024-08-06 20:06:23

|

454人浏览过

|

来源于dev.to

转载

介绍

angular 中新的 @defer 功能是框架增强性能的一部分,特别是在延迟加载和渲染优化方面。以下是 @defer 功能以及 @placeholder 和 @loading 块的快速概述。

@defer 概述

目的

  • @defer 功能旨在延迟应用程序的组件或部分的加载和渲染,直到需要它们为止。这可以显着改善应用程序的初始加载时间并增强用户体验。

用法

  • @defer 可以应用于模板的组件或部分,以指示它们应该延迟加载。这对于大型应用程序或应用程序的某些部分特别有用,这些应用程序或应用程序的部分在用户首次登陆页面时不会立即可见或不需要。

句法

  • 使用 @defer 的语法非常简单,并且与 angular 现有的模板语法无缝集成。以下是如何使用它的示例:
  @defer {
  
  }

优点

  • 性能优化:通过推迟应用程序某些部分的加载,可以减少初始加载时间,从而带来更快、响应更灵敏的用户体验。
  • 资源管理:推迟组件的加载有助于更好的资源管理,因为资源仅在必要时使用。
  • 用户体验:它通过首先加载关键内容并推迟不太关键的内容直到需要时来增强用户体验。

与 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: `
@for(image of list; track image) { @@##@@ }
`, }) export class imagescomponent { list = array(5).fill("https://placehold.co/600x400"); }

这里我们使用@defer,没有任何选项。

angular defer sample application

@defer () { }

现在,查看生成的包,我们可以看到图像组件有自己的块。

使用 @defer 和延迟加载提升角度性能

在网络选项卡中,当页面加载时,我们可以看到该包现在已在运行时加载。

使用 @defer 和延迟加载提升角度性能

将 @defer 与选项一起使用

有多个选项可用于增强用户体验。在本节中,我们将介绍其中的一些。

使用@placeholder

默认情况下,延迟块将在内容在视口中可见时渲染内容。但是,可能会出现延迟,例如,当组件发出 http 请求时。在这些情况下,我们可以使用@placeholder选项。用于占位符的内容不是延迟加载的。首先显示 @placeholder 中的内容,直到 @defer 块的内容准备好渲染为止。占位符本身带有一个称为最小值的可选参数。这允许您设置显示内容的时间。

佳蓝在线销售系统(创业版) 佳蓝在线销售
佳蓝在线销售系统(创业版) 佳蓝在线销售

1、对ASP内核代码进行DLL封装,从而大大提高了用户的访问速度和安全性;2、采用后台生成HTML网页的格式,使程序访问速度得到进一步的提升;3、用户可发展下级会员并在下级购买商品时获得差额利润;4、全新模板选择功能;5、后台增加磁盘绑定功能;6、后台增加库存查询功能;7、后台增加财务统计功能;8、后台面值类型批量设定;9、后台财务曲线报表显示;10、完善订单功能;11、对所有传输的字符串进行安全

下载

这是它的样子:

angular defer sample application

@defer () { } @placeholder (minimum 500ms) {

loading images

}

这是它的样子:

使用 @defer 和延迟加载提升角度性能

使用@loading

@loading 块用于在 @defer 块中定义的内容仍在加载或已开始加载时显示一些内容。这与 @placeholder 块不同,@placeholder 块将在加载开始之前出现。该块带有两个可选参数,after 和minimum。与@placeholder参数类似,minimum参数用于设置显示内容的时间。第二个参数after用于定义显示@loading内容之前的等待时间。

这是它的样子:

Angular Defer Sample Application

@defer () { } @loading (after 1s; minimum 500ms) {

Loading Images

}

虽然您可能在动画 gif 中看不到这一点,但我们告诉块在显示 @loading 内容之前至少等待 1 秒,并显示至少 500 毫秒。

使用 @defer 和延迟加载提升角度性能

结论

angular 中的 @defer 功能是一个强大的工具,通过延迟组件的加载直到需要它们来增强性能和用户体验。通过将此功能与 @placeholder 和 @loading 等选项集成,开发人员可以创建更高效​​、响应更快的应用程序。随着 angular 的不断发展,@defer 等功能将在优化资源管理和提高各种设备和网络条件下的应用程序性能方面发挥至关重要的作用。

使用 @defer 和延迟加载提升角度性能

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

266

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

385

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1024

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1653

2024.08.16

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

95

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

70

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

3

2025.12.30

excel制作动态图表教程
excel制作动态图表教程

本专题整合了excel制作动态图表相关教程,阅读专题下面的文章了解更多详细教程。

24

2025.12.29

freeok看剧入口合集
freeok看剧入口合集

本专题整合了freeok看剧入口网址,阅读下面的文章了解更多网址。

74

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
nginx浅谈
nginx浅谈

共15课时 | 0.8万人学习

前端开发(基础+实战项目合集)
前端开发(基础+实战项目合集)

共60课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号