当前位置: 首页 > 面试题库 >

Angular 2更改检测如何工作?

欧阳杰
2023-03-14
问题内容

在Angular 1中,通过检查$ scope层次结构来进行更改检测。我们将在模板,控制器或组件中隐式或显式创建观察者。

在Angular 2中,我们不再具有$
scope,但是我们确实覆盖了setInterval,setTimeout等。我可以看到Angular如何使用它来触发$
digest,但是Angular如何确定发生了什么变化,特别是考虑到Object.observe从未进入浏览器?

这是一个简单的例子。服务中定义的对象在setInterval中更新。每个时间间隔都会重新编译DOM。

Angular如何辨别AppComponent正在监视该服务,并且该服务的属性值已更改?

var InjectedService = function() {
  var val = {a:1}
  setInterval(() => val.a++, 1000);
  return val;
}

var AppComponent = ng.core
  .Component({
    selector: "app",
    template:
    `
      {{service.a}}
    `
  })
  .Class({
    constructor: function(service) {
      this.service = service;
    }
  })

AppComponent.parameters = [ new ng.core.Inject( InjectedService ) ];

document.addEventListener('DOMContentLoaded', function() {
  ng.platform.browser.bootstrap(AppComponent, [InjectedService])
});

问题答案:

Angular为每个组件创建一个更改检测器对象(请参见ChangeDetectorRef),该对象跟踪每个模板绑定的最后一个值,例如{{service.a}}。默认情况下,在每个异步浏览器事件(例如来自服务器的响应,单击事件或超时事件)之后,都会执行Angular更改检测,并使用这些更改检测器对象对每个绑定进行脏检查。

如果检测到更改,则传播更改。例如,

  • 如果输入属性值更改,则新值将传播到组件的输入属性。
  • 如果{{}}绑定值更改,则新值将传播到DOM property textContent
  • 如果x样式,属性或类绑定中的更改值(即[style.x][attr.x]或)更改,[class.x]则新值将传播到DOM以更新样式,HTML属性或类。

Angular使用Zone.js创建自己的区域(NgZone),该区域对所有异步事件(浏览器DOM事件,超时,AJAX /
XHR)进行猴子修补。这样,更改检测可以在每个异步事件之后自动运行。即,每个异步事件处理程序(函数)完成后,将执行Angular更改检测。



 类似资料:
  • 是否有一种方法可以在每次文件更改时以某种方式触发一个事件?我是指类似的东西(在伪代码中) 我知道我可以周期性地做,但我能在没有计时器的情况下做吗?我希望在用户更新txt文件时(不是通过代码,而是通过打开文件并在里面写入)能够做出一些动作,但我不知道他什么时候会这么做。

  • 我知道我不是第一个问这个的,但是我在前面的问题中找不到答案。我有一个组件 在控制器中,会不时发生变化。 在中,数据以表格格式作为HTML输出。每当发生更改时,此值就会发生更改。 我的组件需要使用作为触发器在Google Map上重绘标记。问题是,当在父级中更改时,ngOnChanges不会激发。我能做什么? 更新:ngOnChanges不工作,但看起来像是正在更新lapsData。在ngInit中

  • 我正在用ExoPlayer 2在Android上开发视频播放器 我正在寻找在SubtitleView(屏幕上部)中检测字幕更改的方法,以在TextView(屏幕下部)中自动滚动字幕<似乎没有听众这么做<我试了几个听众的字幕,但没有效果<你有什么想法吗

  • 问题内容: 如何轻松检测变量何时更改值?我希望每当指定变量更改值时,程序的执行就在调试器上中断。现在,我正在使用Eclipse的调试器。 问题答案: 对于类或实例变量 右键单击大纲视图中的变量 选择“切换监视点” 然后,在breapkoints视图中,可以右键单击结果条目 选择“断点属性” 取消选择“现场访问”。

  • 我有一个带有子组件的组件。 在时间轴组件中,我有这些属性: 如何检查何时从时间轴组件对属性进行更改?每当编辑值发生更改时,我都需要发出该值。 我应该为编辑属性使用一个setter,然后从那里发出吗? 或者有其他方法吗?

  • 变化检测器的目标是知道从上一次变化检测过程运行以来,组件的模板中使用的哪些模型属性已经改变。 为了知道,Angular创建了一个适当的变化检测器类的实例和一个链接到它应该检查的组件。 在我们的示例中,因为我们只有一个和MovieComponent的实例,我们将只有一个MainComponent_ChangeDetector和MovieComponent_ChangeDetector的实例。 下面的