iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >angular中如何优化绑定性能
  • 359
分享到

angular中如何优化绑定性能

2024-04-02 19:04:59 359人浏览 泡泡鱼
摘要

这篇文章主要介绍了angular中如何优化绑定性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1. 为什么要优化双向绑定是一柄双刃剑,提高

这篇文章主要介绍了angular中如何优化绑定性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

1. 为什么要优化

双向绑定是一柄双刃剑,提高开发效率的同时,也牺牲了性能。当然,随着硬件性能的提升,Angular自身性能的提升,对于一般(中小)复杂度的应用,性能问题可以忽略不计。但是对于特殊场景,或复杂页面来说,我们就需要单独的处理数据绑定问题,否则就会有卡顿的现象,影响用户体验。【相关教程推荐:《angular教程》】

2. 编程习惯方面

平时的一些小技巧,小习惯,都可以改善Angular绑定方面的性能。

2.1. NgForOf,加入trackBy提升性能

trackBy定义如何跟踪可迭代项的更改的函数。在迭代器中添加、移动或删除条目时,指令必须重新渲染适当的 DOM 节点。为了最大程度地减少 DOM 中的搅动,仅重新渲染已更改的节点。

默认情况下,变更检测器假定对象实例标识可迭代对象。提供此函数后,指令将使用调用此函数的结果来标识项节点,而不是对象本身的标识。

2.2. Angular数据绑定的三种方式

<div>
    <span>Name {{item.name}}</span>  <!-- 1. 直接绑定 -->
    <span>Classes {{item | classPipe}}</span><!-- 2. pipe方式-->
    <span>Classes {{classes(item)}}</span><!-- 3.绑定方法调用的结果 -->
</div>
  • 直接绑定: 大多数情况下,这都是性能最好的方式。

  • 绑定方法调用的结果:在每个脏值检测过程中,classes方程都要被调用一遍。如果没有特殊需求,应尽量避免这种使用方式。

  • pipe方式: 它和绑定function类似,每次脏值检测classPipe都会被调用。不过Angular给pipe做了优化,加了缓存,如果item和上次相等,则直接返回结果。

<li *ngFor="let item of items; index as i; trackBy: trackByFn">...</li>

2.3. 除非需要,都是用单向绑定,减少监控值的个数

对于一般数据来说,都是只需要展示给用户,不需要修改。那么对于这部分数据,使用单向绑定即可(ts->html).
如:

<!-- 也称插值绑定 -->
 <span>{{yourMessage}}</span>

3. ChangeDetectionStrategy.OnPush 进行性能提升

对于一些很复杂的页面,上面的小技巧就不够用了,不过Angular也是考虑到这些了,提供了不少方法。
Angular 对比 Angularjs 在变化检测上由原来的双向检测(父->子,子->父)变为了单向(父->子)。所以每一次变化检测都会确定性地收敛。
Angular定义一个组件时,可以传入一个变化检测配置项为

changeDetection: ChangeDetectionStrategy.OnPush | ChangeDetectionStrategy.Default;

onpush策略只判断输入的引用(如果是object)是否改变,来判断是否进行脏检查。因此,我们可以使用onpush策略来减少变化检测的开销。

4. 利用ngzone-runOutsideAngular优化

Angular依赖NgZone来监听异步操作,并从根部执行变化检测。换句话说,我们代码中的每一个 addEventListener都会触发脏检查。但是如果我们非常明确,有些addEventListener要执行的东西,不会(或者说可以忽略)影响数据结果,不想然他触发脏检查。比如监测scroll,监测鼠标事件等。

针对这种情况, 我们可以使用zone提供的runOutsideangular,让这些事件不触发脏检查。

this.zone.runOutsideAngular(() => {
    window.document.addEventListener('mousemove', this.bindMouse);
});

5. 手动控制脏检查 ChangeDetectorRef

Angular的ChangeDetectorRef实例上提供了可以绑定或解绑某个组件脏检查的方法。

class ChangeDetectorRef {
  markForCheck() : void     // 通知框架进行变化检查/Change Detection
  detach() : void           // 禁止脏检查
  detectChanges() : void    // 手工触发脏检查, 从该组件到各个子组件执行一次变化检测
  checkNoChanges() : void
  reattach() : void         // detach逆操作,启用脏检查
}

感谢你能够认真阅读完这篇文章,希望小编分享的“angular中如何优化绑定性能”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网html频道,更多相关知识等着你来学习!

--结束END--

本文标题: angular中如何优化绑定性能

本文链接: https://www.lsjlt.com/news/66992.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • angular中如何优化绑定性能
    这篇文章主要介绍了angular中如何优化绑定性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1. 为什么要优化双向绑定是一柄双刃剑,提高...
    99+
    2024-04-02
  • angular怎么进行性能优化
    这篇“angular怎么进行性能优化”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“angu...
    99+
    2024-04-02
  • 如何优化PHP中Memcache缓存的性能和稳定性
    Memcache是一款常用的缓存工具,能够有效地提高Web应用的性能和稳定性。在PHP开发中,Memcache缓存的使用也非常广泛。然而,Memcache缓存在长时间运行中,可能会出现诸如卡顿、内存泄漏和重复存储等问题。这些问题不仅会影响性...
    99+
    2023-05-15
    PHP Memcache 缓存优化
  • Java 中如何优化 load 性能?
    在 Java 程序中,我们经常需要从磁盘或网络中读取数据。在这种情况下,load 操作的性能是非常关键的,因为它直接影响了整个程序的运行效率。本文将介绍一些优化 load 性能的技巧,帮助你提高程序的性能表现。 使用缓存 缓存是提高 ...
    99+
    2023-10-15
    load spring 编程算法
  • Golang 技术性能优化中如何整合性能优化工具?
    Golang 技术性能优化中整合性能优化工具 在 Golang 应用中,性能优化至关重要,而借助性能优化工具可以极大地提升此过程的效率。本文将指导您逐步整合流行的性能优化工具,以帮助您...
    99+
    2024-05-12
    golang 性能优化 git
  • 如何优化MYSQL性能
    本篇文章给大家分享的是有关如何优化MYSQL性能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。  1. MySQL性能优化简介  在Web应用...
    99+
    2024-04-02
  • ArchLinux如何优化性能
    安装最新的内核和驱动程序:确保你的系统使用最新的内核和驱动程序,以获得更好的性能和稳定性。 启用CPU频率调节:通过使用工具...
    99+
    2024-04-02
  • win101909性能如何优化
    这篇文章主要介绍了win101909性能如何优化的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇win101909性能如何优化文章都会有所收获,下面我们一起来看看吧。一、加速开机速度 【Win】+【R】打开【运行...
    99+
    2023-07-01
  • mpvue如何优化性能
    这篇文章主要介绍了mpvue如何优化性能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。先上个优化前后的图:可以看到打包后的代码量从813KB...
    99+
    2024-04-02
  • 如何优化Hibernate性能
    这篇文章主要介绍“如何优化Hibernate性能”,在日常操作中,相信很多人在如何优化Hibernate性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何优化Hibernate性能”的疑惑有所帮助!接下来...
    99+
    2023-06-17
  • Golang 技术性能优化中如何实现分布式性能优化?
    如何实现 golang 分布式性能优化?并发编程: 利用 goroutine 并行执行任务。分布式锁: 使用互斥锁防止并发操作导致数据不一致。分布式缓存: 使用 memcached 减少...
    99+
    2024-05-12
    golang 性能优化 git
  • 如何解析MySQL性能优化中的SQL优化
    如何解析MySQL性能优化中的SQL优化,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注:以 MySQL 为背景,很多内容同时适用于其他关系型...
    99+
    2024-04-02
  • MySQL如何优化性能
    本文小编为大家详细介绍“MySQL如何优化性能”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL如何优化性能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。- MySQL服...
    99+
    2024-04-02
  • Laravel如何优化性能
    这篇文章主要讲解了“Laravel如何优化性能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Laravel如何优化性能”吧!Laravel 的性能优化为何如此重要这篇文章将介绍几个重要的技巧...
    99+
    2023-07-04
  • MariaDB中如何进行性能优化调优
    MariaDB 是 MySQL 的一个分支,因此在进行性能优化调优时,可以遵循类似的步骤。以下是一些常见的性能优化调优方法: 使...
    99+
    2024-04-02
  • SQLServer中如何优化查询性能
    SQLServer中优化查询性能通常包括以下几个方面的方法: 创建合适的索引:通过在查询经常用到的列上创建索引,可以加快查询速度...
    99+
    2024-04-09
    SQLServer
  • Kylin中如何优化查询性能
    使用索引:在数据库表中创建合适的索引可以加快查询速度。可以根据查询的字段和条件创建相应的索引,避免全表扫描。 避免使用SEL...
    99+
    2024-03-07
    Kylin
  • Impala中如何优化查询性能
    在Impala中优化查询性能的一些方法包括: 数据分区:将数据按照某个字段进行分区,可以减少查询时的数据扫描范围,提高查询性能。...
    99+
    2024-03-06
    Impala
  • C++ 中如何优化函数性能?
    c++++ 中优化函数性能包括:1. 内联函数:直接插入调用位置,消除函数调用开销。2. 避免动态内存分配:提前分配和重复使用内存缓冲区,减少分配和释放操作。3. 使用常量引用:确保对象...
    99+
    2024-04-12
    c++ 函数优化
  • CSS中如何优化@font-face性能
    今天就跟大家聊聊有关CSS中如何优化@font-face性能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、 font-face基本用法font-face的基本用法想必大家都是知道...
    99+
    2023-06-08
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作