emberjs/ember.js

@tracked: lazy evaluation

Open

#18,118 创建于 2019年6月19日

在 GitHub 查看
 (4 评论) (0 反应) (0 负责人)JavaScript (22,437 star) (4,216 fork)batch import
DocumentationHelp Wanted

描述

While investigating #18075, I noticed a minor issue, that persists even after the change to WeakMap in #18091, because of the lazy evaluation

class Foo {
  @service someService;

  @tracked someProp = this.someService.serviceProp;
}

Assume Foo gets created by a container lookup or get manually called setOwner on.

Intuitively I would expect the above code to work. And it does. If this.someProp is only accessed later in the template or in init, everything works fine.

However, if you already access this.someProp in the constructor, you get a TypeError, because this.someService is undefined.

While I understand why, I still think this is inconsistent. If we decide to keep lazy evaluation of the initializers, we need to document it well. Would the new static decorators proposal support lazy evaluation in the first place?

贡献者指南