繁体   English   中英

如何循环续集响应

[英]How can I loop a sequelize response

如果我使用 Sequelize 向 Postgres 数据库发出请求,我会得到下一个结果:

 [
  Tags {
    dataValues: { idtag: 18 },
    _previousDataValues: { idtag: 18 },
    _changed: {},
    _modelOptions: {
      ...
    },
    _options: {
      ...
    },
    isNewRecord: false
  },
  Tags {
    dataValues: { idtag: 19 },
    _previousDataValues: { idtag: 19 },
    _changed: {},
    _modelOptions: {
      ...
    },
    _options: {
      ...
    },
    isNewRecord: false
  },
  Tags {
    dataValues: { idtag: 20 },
    _previousDataValues: { idtag: 20 },
    _changed: {},
    _modelOptions: {
      ...
    },
    _options: {
      ...
    },
    isNewRecord: false
  }
]

我找不到循环它以获取“idtag”值的方法。 我试图用 JSON.stringify() 将其解析为 JSON 但它给了我一个字符串。 另外,我试图像它是一个数组一样循环它,但它也不起作用。

假设您的 output 存储到数组中。 现在使用以下代码,您可以收集 idTag 值。

const idTagVals = [];
array.forEach(element => {
    idTagVals.push(element.dataValues.idtag);
});
console.log(idTagVals); //[ 18, 19, 20 ]

根据续集文档

  TagsModel.findAll({where: {} ,plain:true});

将返回普通对象数组。

最后我有答案了。 首先,我使用 JSON.stringify() 转换结果,然后使用 JSON.parse() 转换结果。

let tags = await models.Tags.findAll({ attributes: ['idtag'], where: { iduser: iduser } });

let string = JSON.stringify(tags);
tags = JSON.parse(string);

最后,循环:

tags.forEach(async (tag) => {
   ...
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM