2016-07-05 18 views
6

ho convertito questo codice per l'ultima angolare 2. authentication.service.tstipografico - Il parametro 'u' implicitamente ha un 'qualsiasi' tipo

Quale dovrebbe essere il codice di simile?

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

Hai visto una soluzione per questo errore? –

risposta

9

Si potrebbe provare a utilizzare il tipo User invece di any:

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

e

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

La ragione del problema è un parametro che non è adeguatamente definito, come questo caso è la variabile "u" che segue l'esempio:

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

se non avete il modello di classe di servizio, dovrebbero essere definiti "u" come stringa o un altro tipo quello che ti serve in questo momento:

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

sto usando lo stesso esempio si è utilizzato.

Invece di applicarne uno, impostare il tipo di parametro su User.

Così, il vostro metodo di login potrebbe essere qualcosa di simile:

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

Poi, rimuovere ogni riferimento a any parola chiave.

-2

cambiamento

file di tsconfig.json

"noImplicitAny": false,

e aggiungere

'NG2-formly': 'NPM: NG2-formly/fasci/ng2- formly.umd.js',

a systemjs.config.js

7

considerare l'utilizzo (u: any) => ...

Problemi correlati