angular强制更新ui视图的实现方法

 更新时间:2023年03月04日 13:37:08   作者:前端开发者--小明  
这篇文章主要介绍了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 脏检查没有检测到数据更新吧。。。

解决方案

引入 ChangeDetectorRef ,使视图强刷。

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

 总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • AngularJS 实现JavaScript 动画效果详解

    AngularJS 实现JavaScript 动画效果详解

    本文主要介绍AngularJS 实现 JavaScript 动画的资料,这里整理了详细的资料和简单示例代码,有兴趣的小伙伴可以参考下
    2016-09-09
  • 关于AngularJS中ng-repeat不更新视图的解决方法

    关于AngularJS中ng-repeat不更新视图的解决方法

    今天小编就为大家分享一篇关于AngularJS中ng-repeat不更新视图的解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Angular通过指令动态添加组件问题

    Angular通过指令动态添加组件问题

    这篇文章主要介绍了Angular通过指令动态添加组件问题,文中通过写一个小组件来简单总结下,需要的朋友可以参考下
    2018-07-07
  • Angular8升级至Angular13遇到的问题解决

    Angular8升级至Angular13遇到的问题解决

    这几天升级公司的一个Angular项目遇到了一些问题,下面这篇文章主要给大家介绍了关于Angular8升级至Angular13遇到的问题解决,文中介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • AngularJS通过ng-Img-Crop实现头像截取的示例

    AngularJS通过ng-Img-Crop实现头像截取的示例

    本篇文章主要介绍了AngularJS通过ng-Img-Crop实现头像截取的示例,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08
  • AngularJS表格添加序号的方法

    AngularJS表格添加序号的方法

    这篇文章主要介绍了AngularJS表格添加序号的方法,涉及AngularJS表格的遍历及序号添加实现技巧,需要的朋友可以参考下
    2017-03-03
  • Angular项目中$scope.$apply()方法的使用详解

    Angular项目中$scope.$apply()方法的使用详解

    这篇文章主要给大家介绍了关于Angular项目中$scope.$apply()方法使用的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Angularjs具有一定的参考学习价值,需要的朋友们下面跟着小编一起来看看吧。
    2017-07-07
  • 浅谈angularJS的$watch失效问题的解决方案

    浅谈angularJS的$watch失效问题的解决方案

    本篇文章主要介绍了浅谈angularJS的$watch失效问题的解决方案,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-08-08
  • Angular 4根据组件名称动态创建出组件的方法教程

    Angular 4根据组件名称动态创建出组件的方法教程

    组件是我们在学习angular中必不可少的一部分,下面这篇文章主要给大家介绍了关于Angular 4如何根据组件名称动态创建出组件的相关资料,文中通过图文与示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-11-11
  • Angularjs分页查询的实现

    Angularjs分页查询的实现

    本文给大家分享angularjs实现分页查询功能,代码简单易懂,非常不错,具有参考借鉴价值,需要的朋友参考下
    2017-02-02

最新评论