我在这里有这个小代码:
if (this._error.code == 0) {
localStorage.setItem('pinVouchers', JSON.stringify(this._filters.pin));
$('.loading-wrapper').addClass('hidden');
this._router.navigate(['/dashboard/voucher/list']);
}
else {
this._error.getErrorMessage(this._error.code);
$('.loading-wrapper').addClass('hidden');
alert(this._error.message);
}
在浏览器上调试时,如果错误!= 0,则显然会执行else语句内的部分代码。但是,触发警报后,它将导航到if语句“ this._router.navigate(['/ dashboard / voucher / list']);”内列出的页面。
我已经调试了整个ts文件,但找不到if语句不正确时为什么触发了这行代码。
请帮忙,谢谢!
编辑
这是完整的代码:
import { Component } from '@angular/core';
import { ROUTER_DIRECTIVES, Router } from '@angular/router';
import { CORE_DIRECTIVES, ControlGroup, FORM_DIRECTIVES, Control, FormBuilder, Validators } from '@angular/common';
import { Services } from '../../../services/services';
import { Filters } from '../../../model/Filters';
import { Error } from '../../../model/Error';
@Component({
selector: 'voucher',
templateUrl: 'www/templates/voucher-template.html',
directives: [ CORE_DIRECTIVES, FORM_DIRECTIVES, ROUTER_DIRECTIVES ],
styleUrls: ['www/css/voucher.css'],
providers: [Services]
})
export class voucher {
_PinVouchers: ControlGroup;
_filters: Filters;
_error: Error;
constructor(private services: Services, fb: FormBuilder, public _router: Router) {
this._error = new Error();
this._filters = new Filters();
fb = new FormBuilder();
this._PinVouchers = fb.group({
'pin': new Control(this._filters.pin)
});
}
ngOnInit() {
$('.menu.active').removeClass("active");
$('#vouchersMenu').addClass("active");
$('.submenu.active').removeClass("active");
localStorage.removeItem("pinVouchers");
$(document).ready(() => {
$('#inputPin').keypress(function(key) {
if((key.charCode < 48 || key.charCode > 57) && (key.charCode < 97 || key.charCode > 122) && (key.charCode < 65 || key.charCode > 90) && (key.charCode != 45)) return false;
});
});
}
savePin(filters: Filters){
$('.loading-wrapper').removeClass('hidden');
this.services.getVisitsByPin(this._filters);
this._error.code = JSON.parse(sessionStorage.getItem('error'));
if (this._error.code == 0) {
localStorage.setItem('pinVouchers', JSON.stringify(this._filters.pin));
$('.loading-wrapper').addClass('hidden');
this._router.navigate(['/dashboard/voucher/list']);
}
else {
this._error.getErrorMessage(this._error.code);
$('.loading-wrapper').addClass('hidden');
alert(this._error.message);
}
}
}
我刚刚看到了错误,还在html模板的锚标记内调用了路由器。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句