如何解决通过 Node.js JSON 输出从 Asana Task API 中提取特定的项目 ID
使用 Asana Task API,我们能够查看任务所属的项目列表,以及这些项目的 GID 和注释(描述文本)。
预期结果
此处的整个目标是获取在其 Notes 值中包含 #websiteprojecttemplate 的项目的 GID。我们需要找到该项目的 GID,然后将其输出,以便我们稍后在 Zapier 操作中使用该 GID。
体式任务 API
使用这个 API URL,我们可以看到 API 的输出,它返回项目的数据(包括 GID 和 Notes)。我相信这是 JSON。 https://app.asana.com/api/1.0/tasks/{id}?opt_fields=projects.notes
例如:
https://app.asana.com/api/1.0/tasks/1799885428032109?opt_fields=projects.notes
显示为:
当前代码
理想情况下,Node.js Javascript 代码能够使用 #websiteprojecttemplate
迭代/搜索/查找代码,然后输出匹配的 GID。在这种情况下,它会是:1199916857565229
这是我目前的 JS 代码:
const res = await fetch('https://app.asana.com/api/1.0/tasks/' + inputData.uniqueID + '?opt_fields=projects.notes',{
headers: {
'Authorization': 'Bearer 0/899removedforsecurity24564s'
}
});
const body = await res.json();
const projects = body.data;
output = { id: projects };
输出类似于:
"id" : {
"gid" : "1199885428032109", "projects" : [ {
"gid" : "810573962916457", "notes" : "CRM project to create custom fields for the CRM task"
},{
"gid" : "881219806802782", "notes" : "Helps keep PMs aware of what stage of progress the website projects are at; as well as how many projects each PM has (via saved asana searches)."
},{
"gid" : "1129624391492919", "notes" : "Tracks the stage and progress of converting a lead to a client."
},{
"gid" : "1140671985497468", "notes" : "Additional CRM project to create more custom fields for the CRM task"
},{
"gid" : "1199916857565229", "notes" : "Created from the #websiteprojecttemplate."
} ]
}
但我需要它不输出整个正文的数据,而只输出其 gid
值中包含 #websiteprojecttemplate
的 notes
值。
TL;DR
我们如何更新当前代码,使其可以遍历 gid
并找到 #websiteprojecttemplate
中包含 notes
的那个,并输出 gid
编号其中?
解决方法
我认为您的问题归结为如何在数组中查找元素。
const project = projects.projects.find(p => p.notes.includes("#websiteprojecttemplate"));
if (project) {
console.log(project.gid);
} else {
console.log("no matching project");
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。