2016-07-05 4 views
6

ich diesen Code auf den neuesten authentication.service.ts Angular 2. umgewandeltTyposkript - Parameter ‚u‘ hat implizit einen ‚beliebigen‘ Typen

Was sollte der Code aussehen?

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('[email protected]','adm9'), 
    new User('[email protected]','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']); 
    } 
    } 
} 
+0

Haben Sie eine Lösung für diesen Fehler gefunden? –

Antwort

9

Sie könnten versuchen, den User Typ verwenden statt any:

var users:User[] = [ 
    (...) 
]; 

und

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

Der Grund des Problems ist ein Parameter, der nicht richtig definiert ist, wie dieser Fall ist die Variable "u", die dem Beispiel folgt:

, wenn Sie nicht das Klassenmodell von Service haben, sollten definiert „u“ als String oder ein anderer Typ sein, was Sie im Moment brauchen:

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

Ich verwende das gleiche Beispiel Sie verwendet haben.

Anstelle eines beliebigen Parameters den Parametertyp auf User einstellen.

So würde Ihre Login-Methode so etwas wie dieses:

login(user: User): boolean { ...

Dann entfernen Sie alle Verweise auf any Schlüsselwort.

-2

Änderung

tsconfig.json Datei

"noImplicitAny": false,

und fügen

'NG2-heitlich': ‚npm: NG2-heitlich/Bündel/ng2- formly.umd.js',

systemjs.config.js

7

Erwägen Sie die Verwendung (u: any) => ...

Verwandte Themen