[英]Angular2, generic overlay component for all other components inside the app
我有以下两个组成部分:
覆盖
@Component({
selector: 'overlay',
template: '<div class="check"><ng-content></ng-content></div>'
})
export class Overlay {
save(params) {
//bunch of stuff that are commonly used
}
}
myComponent(还有很多这样的)
@Component({
selector: 'myComponent',
directives: [Overlay],
template: '<overlay><form (ngSubmit)="save({ name: 'sam', lastName: 'jones' })">I'm the component. Click <input type="submit">Here</input> to save me!</form></overlay>'
})
export class MyComponent {
}
没有抛出错误,这个解决方案不起作用,Angular2只是跳过两个组件初始化。 无论如何,我想你在这里得到了这个想法。 有一个共同的组件需要包装许多其他组件,因此它需要是通用的。 它有一个template
所以服务不能完成这项工作。 我没有使用自定义注释,也许他们可以做这样的事情? 有关如何实现这种功能的任何想法?
注意:叠加层包含逻辑和模板,这些都是需要使用它的任何其他组件所需要的。 模板是一个复杂的模态对话框,包含动画,消息,淡入淡出等......这在整个解决方案中很常见。
更新
好吧也许这不是你的问题的直接答案,但从你的评论我想你想在你的应用程序中实现模态。 我还没有完成它 ,但在不久的将来我会(这是我应用程序要求的一部分)。
首先我不使用bootstrap javascript,因为我已经使用了角度。 你唯一需要的是bootstrap css 。
考虑以下根模板:
<my-app></my-app>
<my-modal>
<div class="modal-container">
<div class="modal-content">{{modalContent}}</div>
</div>
</my-modal>
您可以从任何component
显示模态。 诀窍是注入modal-service
来发送全局事件 。 看到这个答案,看看它是如何工作的。
您可以将任何对象作为event
发送。 此事件对象可能包含模态的内容或key
因此模态component
可以从其他位置获取它。
您的ModalComponent
应订阅该事件。 在事件中,您可以通过几种方式显示和隐藏它(模态组件),我确信您已经知道。 使用结构指令是一种方法。
模态是一个容器( .modal-container
),具有透明背景的视口 width
和height
。 Modal的内容( .modal-content
)是另一个具有固定width
和height
以及absolute
位置的容器。 如果您想要自举样式,可以添加它,对于动画,您可以使用角度动画
我目前正在使用类似的方法进行菜单栏,它的效果非常好!!
我为这个特定的任务创建了一个,并考虑将bootstrap模式嵌入作为模板,但遇到了一些问题,例如,bootstrap模式中唯一有用的部分是类名。 毫不奇怪,因为我需要区分窗口模态和组件上的进度模态,所以不希望这个特定的任务。
覆盖
@Component({
selector: 'overlay',
template:
`<div [ngClass]="isOpen ? 'opened' : 'closed'">
<div class="modal" role="dialog">
<div class="modalBody">
<div *ngIf="isSaving">
<span class="text-success text-bold">
Saving...
</span>
</div>
<div *ngIf="isSaved">
<span class="text-success text-bold">
Saved.
</span>
</div>
</div>
</div>
</div>`,
styles: [
'.modal { position:absolute; width: 100%; height: 100%; margin: -30px; background-color: rgba(255, 255, 255, 0.7); z-index: 1000; text-align: center; }',
'.closed { visibility: hidden; }',
'.opened { visibility: visible; }',
'.modalBody { top: 45%; left: 25%; width: 50%; position: absolute; }',
'.text-bold { font-weight: 800; font-size: 1.5em; }'
]
})
export class Overlay implements OnChanges, AfterContentInit {
@Input() isSaving: boolean = false;
@Input() isSaved: boolean = false;
@Input() containerElement: HTMLElement;
isOpen = false;
private modalElement;
constructor(private element: ElementRef, private animationBuilder: AnimationBuilder) { }
ngOnChanges() {
if (this.modalElement) {
if (this.isSaving == true || this.isSaved == true) {
this.toggleAnimation(true);
}
else if (this.isSaving == false && this.isSaved == false) {
this.toggleAnimation(false);
}
}
}
ngAfterContentInit() {
this.containerElement.style.position = 'relative';
this.modalElement = this.element.nativeElement.querySelector('.modal');
}
private toggleAnimation(isOpen) {
var startCss = { backgroundColor: 'rgba(255, 255, 255, 0)' };
var endCss = { backgroundColor: 'rgba(255, 255, 255, 0.7)' };
if (isOpen) {
this.isOpen = true
this.animation(
true,
this.modalElement,
400,
startCss,
endCss,
null
);
}
else {
this.animation(
isOpen,
this.modalElement,
400,
startCss,
endCss,
() => {
this.isOpen = false;
}
);
}
}
private animation(isStart, element, duration, startCss, endCss, finishedCallback) {
var animation = this.animationBuilder.css();
animation.setDuration(duration);
if (isStart) {
animation.setFromStyles(startCss).setToStyles(endCss);
} else {
animation.setFromStyles(endCss).setToStyles(startCss)
}
animation.start(element);
if (finishedCallback) {
setTimeout(finishedCallback, duration);
}
}
}
用法
因此,您需要一个相对容器才能使overlay
填充其父级。 css肯定需要修改以适应一些场景,例如移动设备和非定位容器。 以下是它目前的使用方式:
HTML
<form action="/edit" method="post" #myForm="ngForm" (ngSubmit)="save ajax method that will update the isSaving and isSaved accordingly" novalidate>
<div style="position: relative;" #overlayContainer>
<overlay [isSaving]="isSaving" [isSaved]="isSaved" [containerElement]="overlayContainer"></overlay>
</div>
</form>
保存form
,在containerElement
显示一个overlay
400ms并逐渐淡出并在之后隐藏,直到下一次保存尝试。 isSaving
和isSaved
绑定值是希望使用overlay
的任何组件的责任。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.