我希望我的模式仅在验证表单 angular 后打开?感谢您的回答
I want my modal to open only after validates the form angular? Appreciate your answer
当我点击保存时,我想要验证我的表单然后弹出窗口应该打开。?但是现在当我点击保存弹出窗口时打开,关闭弹出窗口后,它正在显示验证。我试过了,但没用
<button class="btn btn-primary py-2 px-3 mt-3" type="submit" data-toggle="modal" data-target="#saveCerts">Save</button>
模态:
<div class="modal fade modal-mini modal-primary" id="saveCerts" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog modal-small">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title pull-left text-white">Alert</h4>
<button mat-button type="button" class="close" data-dismiss="modal" aria-hidden="true"><i class="material-icons">clear</i></button>
</div>
<div class="modal-body">
<p>Make sure you are providing your finalized label name. You cannot change it in future once you start using it in your projects. </p>
</div>
<div class="modal-footer justify-content-center">
<button mat-raised-button type="button" data-dismiss="modal" class="btn btn-primary px-3 -y-2" (click)="uploadCerts()">OK
</button>
</div>
</div>
</div>
</div>
ts:
uploadCerts(){
if (this.labelvalue == null || this.labelvalue == '') {
this.nolabel = true;
return;
}
let format = /[ `!@#$%^&*()_+\-=\[\]{};':"\|,.<>\/?~]/;
if(format.test(this.labelvalue)){
this.noSpecialChar = true;
return;
}
const ind = this.sslfileDetails.filter((x => x.label == this.labelvalue))
if(ind.length > 0){
this.sharedService.errorAlert("Label already taken")
return
}
if(this.rootdata == undefined && this.certdata == undefined){
if(this.combidata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}else if(this.rootdata != undefined){
if(this.certdata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}else if(this.certdata != undefined){
if(this.rootdata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}
将验证移入 dovalidation
方法。
添加验证完成后打开模型的按钮
<button [hidden]="true" id="openModalButton" type="button" data-toggle="modal" data-target="#saveCerts"></button>
<button class="btn btn-primary py-2 px-3 mt-3" (click)="dovalidation()" type="button" >Save</button>
并在通过 dovalidation
方法成功验证后通过
打开模型
document.getElementById("openModalButton").click();
当我点击保存时,我想要验证我的表单然后弹出窗口应该打开。?但是现在当我点击保存弹出窗口时打开,关闭弹出窗口后,它正在显示验证。我试过了,但没用
<button class="btn btn-primary py-2 px-3 mt-3" type="submit" data-toggle="modal" data-target="#saveCerts">Save</button>
模态:
<div class="modal fade modal-mini modal-primary" id="saveCerts" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-dialog modal-small">
<div class="modal-content">
<div class="modal-header">
<h4 class="modal-title pull-left text-white">Alert</h4>
<button mat-button type="button" class="close" data-dismiss="modal" aria-hidden="true"><i class="material-icons">clear</i></button>
</div>
<div class="modal-body">
<p>Make sure you are providing your finalized label name. You cannot change it in future once you start using it in your projects. </p>
</div>
<div class="modal-footer justify-content-center">
<button mat-raised-button type="button" data-dismiss="modal" class="btn btn-primary px-3 -y-2" (click)="uploadCerts()">OK
</button>
</div>
</div>
</div>
</div>
ts:
uploadCerts(){
if (this.labelvalue == null || this.labelvalue == '') {
this.nolabel = true;
return;
}
let format = /[ `!@#$%^&*()_+\-=\[\]{};':"\|,.<>\/?~]/;
if(format.test(this.labelvalue)){
this.noSpecialChar = true;
return;
}
const ind = this.sslfileDetails.filter((x => x.label == this.labelvalue))
if(ind.length > 0){
this.sharedService.errorAlert("Label already taken")
return
}
if(this.rootdata == undefined && this.certdata == undefined){
if(this.combidata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}else if(this.rootdata != undefined){
if(this.certdata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}else if(this.certdata != undefined){
if(this.rootdata == undefined){
this.sharedService.errorAlert("Please upload either .crt and .key certificates or Combined certificate")
return;
}
}
将验证移入 dovalidation
方法。
添加验证完成后打开模型的按钮
<button [hidden]="true" id="openModalButton" type="button" data-toggle="modal" data-target="#saveCerts"></button>
<button class="btn btn-primary py-2 px-3 mt-3" (click)="dovalidation()" type="button" >Save</button>
并在通过 dovalidation
方法成功验证后通过
document.getElementById("openModalButton").click();