温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

angular强制更新ui视图如何实现

发布时间:2023-03-07 15:43:16 来源:亿速云 阅读:133 作者:iii 栏目:开发技术

本文小编为大家详细介绍“angular强制更新ui视图如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“angular强制更新ui视图如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

    angular 强制更新ui视图方法

    强制更新ui视图方法主要用在数据已经改变,但是ui展示视图不跟新情况

    1 主要使用方法类 ChangeDetectorRef

    Angular 各种视图的基础类,提供变更检测功能。

    变更检测树会收集要检查的所有视图。

    使用这些方法从树中添加或移除视图、初始化变更检测并显式地把这些视图标记为脏的,意思是它们变了、需要重新渲染。

    1.1类方法一:markForCheck()

    当输入已更改或视图中发生了事件时,组件通常会标记为脏的(需要重新渲染)。调用此方法会确保即使那些触发器没有被触发,也仍然检查该组件。

    1.2类方法一:detach()

    从变更检测树中分离开视图。 已分离的视图在重新附加上去之前不会被检查。 与 detectChanges() 结合使用,可以实现局部变更检测。

    即使已分离的视图已标记为脏的,它们在重新附加上去之前也不会被检查。

    1.3类方法一:detectChanges()

    检查该视图及其子视图。与 detach 结合使用可以实现局部变更检测。

    1.4类方法一:checkNoChanges()

    检查变更检测器及其子检测器,如果检测到任何更改,则抛出异常。

    1.5类方法一:reattach()

    把以前分离开的视图重新附加到变更检测树上。 视图会被默认附加到这棵树上。引入 ChangeDetectorRef

    import { ChangeDetectorRef } from '@angular/core';

    2 赋值引入

    constructor(private ref: ChangeDetectorRef) { }

    3方法中调用

        this.ref.markForCheck();    // 就是在拿到数据后,执行这两行代码,这是关键
        this.ref.detectChanges();

    angular踩坑 数据发生改变,视图未更新

    大多数情况下,页面的视图会随着数据的改变而改变,少数情况下,数据变了,而视图不更新。

    angular强制更新ui视图如何实现

    左侧的视图,右侧数据,数据改变时,视图未更新。。。。具体原因呢,可能是angular 脏检查没有检测到数据更新吧。。。

    解决方案

    引入 ChangeDetectorRef ,使视图强刷。

    import { Component, OnInit, Input, ChangeDetectorRef} from '@angular/core';

    angular强制更新ui视图如何实现

    angular强制更新ui视图如何实现

    读到这里,这篇“angular强制更新ui视图如何实现”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI