【发布时间】:2023-03-29 06:06:01
【问题描述】:
我的代码中有几个错误。我正在使用 Angular 2 + TSLint:
constructor(http: Http) {
this.http = http;
--> let currentUser = JSON.parse(localStorage.getItem("currentUser"));
this.token = currentUser && currentUser.token;
}
在 currentUser 我有这个错误:message: 'expected variable-declaration: 'currentUser' to have a typedef;
public loginC (username: string, password: string): Observable<boolean> {
return this.http.post( authURL + loginURL,
--> JSON.stringify({ password: password, username: username }))
.map((response: Response) => {
let token: string = response.json() && response.json().token;
if (token) {
this.token = token;
--> localStorage.setItem("currentUser", JSON.stringify({token: token, username: username}));
return true;
} else {
return false;
}
});
}
在password: password, username: username 这个:message: 'Expected property shorthand in object literal.
我真的很理解这一点。最后我可以写一个简单的model: any {};
export class LoginComponent {
--> public model: any = {};
public loading: boolean = false;
public error: string = "";
constructor (private router: Router, private authenticationService: ServerDataComponent) {
//
}
public login(): void {
this.loading = true;
this.authenticationService.loginC(this.model.username, this.model.password)
.subscribe(result => {
--> if (result === true) {
this.router.navigate(["/table_per"]);
} else {
this.error = "Введен неверный логин и/или пароль";
this.loading = false;
}
});
}
对于任何 - Type declaration of 'any' is forbidden;
Ror 结果 - expected arrow-parameter: 'result' to have a typedef
【问题讨论】:
标签: angular typescript tslint