在测试我的UserRouter时,我使用了一个json文件

data.json

[
  {
    "id": 1,
    "name": "Luke Cage",
    "aliases": ["Carl Lucas", "Power Man", "Mr. Bulletproof", "Hero for Hire"],
    "occupation": "bartender",
    "gender": "male",
    "height": {
      "ft": 6,
      "in": 3
    },
    "hair": "bald",
    "eyes": "brown",
    "powers": [
      "strength",
      "durability",
      "healing"
    ]
  },
  {
  ...
  }
]

构建我的应用程序,我得到以下TS错误

ERROR in ...../UserRouter.ts
(30,27): error TS7006: Parameter 'user' implicitly has an 'any' type.

UserRouter.ts

import {Router, Request, Response, NextFunction} from 'express';
const Users = require('../data');

export class UserRouter {
  router: Router;

  constructor() {
  ...
  }

  /**
   * GET one User by id
   */
  public getOne(req: Request, res: Response, _next: NextFunction) {
    let query = parseInt(req.params.id);
 /*[30]->*/let user = Users.find(user => user.id === query);
    if (user) {
      res.status(200)
        .send({
          message: 'Success',
          status: res.status,
          user
        });
    }
    else {
      res.status(404)
        .send({
          message: 'No User found with the given id.',
          status: res.status
        });
    }
  }


}

const userRouter = new UserRouter().router;
export default userRouter;

当前回答

你正在使用——noImplicitAny, TypeScript不知道Users对象的类型。在这种情况下,您需要显式地定义用户类型。

更改这一行:

let user = Users.find(user => user.id === query);

:

let user = Users.find((user: any) => user.id === query); 
// use "any" or some other interface to type this argument

或者定义用户对象的类型:

//...
interface User {
    id: number;
    name: string;
    aliases: string[];
    occupation: string;
    gender: string;
    height: {ft: number; in: number;}
    hair: string;
    eyes: string;
    powers: string[]
}
//...
const Users = <User[]>require('../data');
//...

其他回答

我的情况:


export default function ({user, path}) {
    return (
        //...
    )
}

我改成了

export default function ({user, path} : {
    user: string
    path: string
}) {
    return (
        //...
    )
}

只需在jsconfig中添加"checkJs": false。json文件

你正在使用——noImplicitAny, TypeScript不知道Users对象的类型。在这种情况下,您需要显式地定义用户类型。

更改这一行:

let user = Users.find(user => user.id === query);

:

let user = Users.find((user: any) => user.id === query); 
// use "any" or some other interface to type this argument

或者定义用户对象的类型:

//...
interface User {
    id: number;
    name: string;
    aliases: string[];
    occupation: string;
    gender: string;
    height: {ft: number; in: number;}
    hair: string;
    eyes: string;
    powers: string[]
}
//...
const Users = <User[]>require('../data');
//...

尝试声明用户的类型。 如

let user:Object = {sample object}

遵循这个方法。 作为

let var:type = val

我在Angular的函数参数中发现了这个问题。

在我的代码给出错误之前

参数'event'隐含有一个'any'类型

这是代码

changeInpValue(event)
{
    this.inp = event.target.value;
}

这里是修改后的参数写:any,错误就解决了

changeInpValue(event : any)
{
    this.inp = event.target.value;
}

对我来说很好。