“类型‘string | string[]’不可分配给类型‘string’

Oop*_*ops 8 node.js query-string swagger typescript

我正在使用 Node + TypeScript 和集成的 swagger 进行 API 调用。我有一个大摇大摆的请求

http://localhost:3033/employees/search/?username=test

这里我想找到 username = test 的记录。

因此,我使用 URL 模块解析查询字符串,如下所示,并在控制台中获取用户名。

var params = URL.parse(req.url, true).query;
console.log(params); //gives me [Object: null prototype] { username: 'test' } in my console
Run Code Online (Sandbox Code Playgroud)

但是每当我尝试将 params.username 分配给如下所示的常量时

const username:string =params.username;
Run Code Online (Sandbox Code Playgroud)

它给了我以下错误

输入“字符串|” string[]' 不可分配给类型“string”。类型“string[]”不可分配给类型“string”。

我的完整代码如下

import * as URL from 'url';

public getUserByName = async (req: Request, res: Response, next: NextFunction) => {
var params = URL.parse(req.url, true).query;
const username:string =params.username;

try {
  const findOneUserData: Employee = await this.userService.findUserByName(username);
  res.status(200).json({ data: findOneUserData, message: 'findOne' });
} catch (error) {
  next(error);
}
Run Code Online (Sandbox Code Playgroud)

}

小智 7

您代码中的问题是, params.username 可以是 astring或 a string[]

以下场景返回一个简单的字符串

const {query} = url.parse('example.com?test=1', true);
// query.test === '1'
Run Code Online (Sandbox Code Playgroud)

而下面的示例返回一个数组,因为相同的查询参数键被使用了两次

const {query} = url.parse('example.com?test=1&test=2', true);
//query.test === ['1', '2']
Run Code Online (Sandbox Code Playgroud)

所以你可以明确地处理数组情况,例如

const username = Array.isArray(params.username) ? params.username[0] : params.username
Run Code Online (Sandbox Code Playgroud)

  • 我也是这么做的。但感觉不对:/sf/ask/4989158331/ (2认同)

Oop*_*ops 5

好吧,所以我犯了我犯的错误。第一个是 @ford04 在评论中提到的。我直接将 Object 分配给字符串。我在问题中改变了它。第二个是通过函数将解析的查询字符串转换为字符串toString()

public getUserByName = async(req: Request, res: Response, next: NextFunction) => {
  var params = URL.parse(req.url, true).query;
  console.log(params.username);
  const username: string = params.username.toString(); //this is the key

  try {
    const findOneUserData: Employee = await this.userService.findUserByName(username);
    res.status(200).json({
      data: findOneUserData,
      message: 'findOne'
    });
  } catch (error) {
    next(error);
  }
}
Run Code Online (Sandbox Code Playgroud)