Typescript – 参数’u’隐式具有’any’类型

前端之家收集整理的这篇文章主要介绍了Typescript – 参数’u’隐式具有’any’类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我将此代码转换为最新的Angular 2. authentication.service.ts

代码应该是什么样的?

app/auth/auth.service.ts(30,40): error TS7006: Parameter 'u' implicitly has an 'any' type.

// services/auth.service.ts
import {Injectable} from '@angular/core';
import {Router} from '@angular/router';

//http://4dev.tech/2016/03/login-screen-and-authentication-with-angular2/
//https://github.com/leonardohjines/angular2-login
export class User {
  constructor(
    public email: string,public password: string) { }
}

var users:any = [
  new User('admin@admin.com','adm9'),new User('user1@gmail.com','a23')
];

@Injectable()
export class AuthenticationService {

  constructor(
    private _router: Router){}

  logout() {
    localStorage.removeItem("user");
    this._router.navigate(['Login']);
  }

  login(user:any){
    var authenticatedUser = users.find(u => u.email === user.email);
    if (authenticatedUser){
      localStorage.setItem("user",authenticatedUser);
      this._router.navigate(['Home']);      
      return true;
    }
    return false;

  }

   checkCredentials( ){
    if (localStorage.getItem("user") === null){
        this._router.navigate(['Login']);
    }
  } 
}
您可以尝试使用用户类型而不是任何:
var users:User[] = [
  (...)
];

var authenticatedUser = users.find((u:User) => u.email === user.email);

猜你在找的Angularjs相关文章