- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个 Angular 2 应用程序,其中包含一个组件,我试图相对于另一个组件的 HTML 元素定位其 HTML 元素。为了计算准确的坐标,我需要知道浏览器呈现的我自己的元素的宽度和高度。
我正在使用 window.getComputedStyle(this.elementRef.nativeElement)
来获取这些属性。我注意到,随着页面的呈现,属性不断变化,直到页面呈现完成。为了了解任何更改并调整位置,我检查了组件的 ngAfterViewChecked
方法中的值。
但是,当渲染导致新的计算样式属性时,ngAfterViewChecked
似乎没有被调用,因为我发现我的钩子(Hook)不是不再调用,即使计算的样式属性仍在变化。我假设 Angular 框架不是为了检测这种变化而设计的。
我的第一次尝试是实现 ngDoCheck
Hook ,但似乎在一段时间后和计算出的样式属性具有最终值之前都没有调用这个 Hook 。我假设我还没有完全理解这个钩子(Hook)究竟应该在什么时候被调用。
我终于发现,如果我在 ngAfterViewChecked
中实现一个 setTimeout
函数,这会导致稍后再次调用同一个钩子(Hook),即使我只传递一个虚拟对象功能如:
setTimeout(() => {}, 500);
但坦率地说,我不明白为什么会这样。 有人可以向我解释一下 setTimeout
和 ngAfterViewChecked
Hook 之间的联系吗?
虽然这似乎是一个有点肮脏的解决方法:检测和处理计算样式属性更改的正确“Angular ”方法是什么?
代码摘录:
export class MyComponent implements OnInit, AfterViewChecked
{
private cssWidth: number;
private cssHeight: number;
constructor(private elementRef: ElementRef, private renderer: Renderer2)
{
}
ngAfterViewChecked()
{
console.log("ngAfterViewChecked");
this.updateView();
}
public updateView()
{
const sizeX = parseFloat(window.getComputedStyle(this.elementRef.nativeElement).width) || 0;
const sizeY = parseFloat(window.getComputedStyle(this.elementRef.nativeElement.height) || 0;
if (sizeX === this.cssWidth && sizeY === this.cssHeight) {
// no change
return;
}
console.log("Change detected!");
// TODO Does not work without this dummy timeout function (else no more changes detected) - why so??
setTimeout(() => {}, 500);
[.. doing the positioning here ..]
}
最佳答案
见上图here查看生命周期图。如果您在 doCheck 中的 Hook 不起作用,则 AfterViewChecked 也不会起作用,因为 doCheck 会启动 AfterViewChecked。
每次异步进程完成时,都会发生另一轮 doCheck。那会调用 AfterViewChecked,然后调用您的 updateView 函数。 SetTimout() 是一个异步过程。我怀疑上面的代码会原样无限循环。
我相信您想要的是让您在此处显示的内容的父组件使用 ngAfterViewChecked() 并调用 updateView()。探讨了该主题 here .
让两个组件协同工作的 Angular 方法是让父组件可以在子组件之间传达更改,因为父组件是可以查看子组件中发生的事件的上下文。
我个人会使用的解决方案是 EventEmitter,在未显示的组件中,在 ngOnInit() 函数中。它会通知父级它已初始化。然后,在父组件中,有一个函数调用发生在发出的事件上,告诉子组件你在这里更新 View 。
关于javascript - 如何使用 Angular 2 正确检测计算样式属性的变化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43659016/
你能比较一下属性吗 我想禁用文本框“txtName”。有两种方式 使用javascript,txtName.disabled = true 使用 ASP.NET, 哪种方法更好,为什么? 最佳答案 我
Count 属性 返回一个集合或 Dictionary 对象包含的项目数。只读。 object.Count object 可以是“应用于”列表中列出的任何集合或对
CompareMode 属性 设置并返回在 Dictionary 对象中比较字符串关键字的比较模式。 object.CompareMode[ = compare] 参数
Column 属性 只读属性,返回 TextStream 文件中当前字符位置的列号。 object.Column object 通常是 TextStream 对象的名称。
AvailableSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。 object.AvailableSpace object 应为 Drive 
Attributes 属性 设置或返回文件或文件夹的属性。可读写或只读(与属性有关)。 object.Attributes [= newattributes] 参数 object
AtEndOfStream 属性 如果文件指针位于 TextStream 文件末,则返回 True;否则如果不为只读则返回 False。 object.A
AtEndOfLine 属性 TextStream 文件中,如果文件指针指向行末标记,就返回 True;否则如果不是只读则返回 False。 object.AtEn
RootFolder 属性 返回一个 Folder 对象,表示指定驱动器的根文件夹。只读。 object.RootFolder object 应为 Dr
Path 属性 返回指定文件、文件夹或驱动器的路径。 object.Path object 应为 File、Folder 或 Drive 对象的名称。 说明 对于驱动器,路径不包含根目录。
ParentFolder 属性 返回指定文件或文件夹的父文件夹。只读。 object.ParentFolder object 应为 File 或 Folder 对象的名称。 说明 以下代码
Name 属性 设置或返回指定的文件或文件夹的名称。可读写。 object.Name [= newname] 参数 object 必选项。应为 File 或&
Line 属性 只读属性,返回 TextStream 文件中的当前行号。 object.Line object 通常是 TextStream 对象的名称。 说明 文件刚
Key 属性 在 Dictionary 对象中设置 key。 object.Key(key) = newkey 参数 object 必选项。通常是 Dictionary 
Item 属性 设置或返回 Dictionary 对象中指定的 key 对应的 item,或返回集合中基于指定的 key 的&
IsRootFolder 属性 如果指定的文件夹是根文件夹,返回 True;否则返回 False。 object.IsRootFolder object 应为&n
IsReady 属性 如果指定的驱动器就绪,返回 True;否则返回 False。 object.IsReady object 应为 Drive&nbs
FreeSpace 属性 返回指定的驱动器或网络共享对于用户的可用空间大小。只读。 object.FreeSpace object 应为 Drive 对象的名称。
FileSystem 属性 返回指定的驱动器使用的文件系统的类型。 object.FileSystem object 应为 Drive 对象的名称。 说明 可
Files 属性 返回由指定文件夹中所有 File 对象(包括隐藏文件和系统文件)组成的 Files 集合。 object.Files object&n
我是一名优秀的程序员,十分优秀!