杰网资源 Design By www.escxy.com
本文实例讲述了Angular2.0实现modal对话框的方法。分享给大家供大家参考,具体如下:
觉得写的比较巧妙的就是样式的选取~记录下
CSS部分
.font {
font-family: "Microsoft YaHei", Arial;
font-size: 12px;
color: #333333;
}
.ky-modal-content {
min-width: 520px;
min-height: 240px;
}
.ky-modal-header {
/*height : 40px;*/
padding: 0 10px 0 10px;
}
.ky-modal-title {
font-size: 16px;
font-weight: 100;
}
.ky-modal-body {
min-height: 110px;
text-align: center;
}
.ky-modal-footer {
height: 30px;
border-top: 0;
text-align: -webkit-center;
}
.ky-modal-message {
padding-left: 3px;
vertical-align: middle;
}
.ky-modal-icon {
font-size: 16px;
vertical-align: middle;
}
.ky-modal-question-icon {
color:#ff8000;
}
.ky-modal-check-icon {
color:green;
}
.ky-modal-exclamation-icon {
color:red;
}
.ky-modal-close {
outline: none;
font-size: 30px;
margin-top: 8px;
font-weight: 100;
vertical-align: -webkit-baseline-middle;
}
.vertical-align-center {
display: flex;
display: -webkit-box;
display: -moz-box;
-webkit-box-align: center;
-moz-box-align: center;
text-align: -webkit-center;
}
HTML部分
<div [id]="id" class="modal fade" tabindex="-1" role="dialog" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content ky-modal-content">
<div class="modal-header ky-modal-header">
<button type="button" class="close ky-modal-close" data-dismiss="modal" aria-label="Close">
<span style="position: fixed;right: 10px;top:-6px" aria-hidden="true">×</span>
</button>
<h4 class="modal-title ky-modal-title" >{{title}}</h4>
</div>
<div class="modal-body ky-modal-body vertical-align-center">
<div>
<span style="font-size:18px;"> <span style="color:#ff0000;"><i class="fa ky-modal-icon" [ngClass]="iconClass" aria-hidden="true"></i></span></span>
<span class="ky-modal-message">{{message}}</span>
</div>
</div>
<div class="modal-footer ky-modal-footer">
<ky-button [type]="conformButtonType" data-dismiss="modal" (click)="confirmButtonDown()">{{confirmText}}</ky-button>
<ky-button [type]="'cancel'" data-dismiss="modal" (click)="cancelButtonDown()">{{cancelText}}</ky-button>
</div>
</div>
</div>
</div>
JS部分
import { Component, Input, Output, EventEmitter, OnInit } from '@angular/core';
@Component({
moduleId: module.id,
selector: 'ky-modal',
styleUrls: ['./ky-modal.css'],
templateUrl: './ky-modal.component.html',
})
export class KyModalComponent implements OnInit {
@Input() title:string = '';
@Input() type:string = '';
@Input() message:string = '';
@Input() confirmText:string = '';
@Input() cancelText:string = '';
@Input() id:string;
@Input() conformButtonType:string;
iconType ='question';
iconClass :any = {'fa-question-circle':false,
'fa-check-circle':false,
'fa-exclamation-circle':false};
typeList = ['question', 'check', 'exclamation'];
@Output() actionButtonDown = new EventEmitter();
@Output() undoButtonDown = new EventEmitter();
cancelButtonDown() {
this.undoButtonDown.emit('event');
}
confirmButtonDown() {
this.actionButtonDown.emit('event');
}
determine() {
let that = this;
if(that.type && _.contains(that.typeList,that.type)) {
that.iconType = that.type;
}
that.iconClass[`fa-${that.iconType}-circle`] = true;
that.iconClass[`ky-modal-${that.iconType}-icon`] = true;</span>
}
ngOnInit() {
this.determine();
}
}
更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS指令操作技巧总结》、《AngularJS入门与进阶教程》及《AngularJS MVC架构总结》
希望本文所述对大家AngularJS程序设计有所帮助。
杰网资源 Design By www.escxy.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
杰网资源 Design By www.escxy.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。



