在我的指令中,我有以下内容,通常可以检测图像的正确高度。但是,如果没有超时黑客,它很少起作用。有没有更可靠的方法可以做到这一点?
import {Directive, ElementRef, Renderer} from '@angular/core';
@Directive({
selector: '[custom-header]', // Attribute selector
})
export class CustomHeader {
header: any;
headerHeight: any;
constructor(public element: ElementRef, public renderer: Renderer) {
// console.log('Hello CustomHeader Directive');
}
ngAfterContentInit() {
var test = this.element.nativeElement;
setTimeout(function () {
var content = test.getElementsByClassName('header-image')[0];
alert(content.clientHeight);
}, 600);
}
}
在组件视图中(我正在使用 Ionic(;
<ion-header class="header" custom-header id="header">
<a (click)="goToRoot()" ><img class="header-image" src="assets/img/topBar-iPad.png" alt=""/></a>
</ion-header>
这可能
对你有用
<img class="header-image" src="assets/img/topBar-iPad.png" alt=""
#me (load)="headerHeight = me.clientHeight"/>