javascript - 通过 Node.js JSON 输出从 Asana Task API 中提取特定项目 ID
问题描述
使用Asana Task API,我们可以查看任务所属的项目列表,以及这些项目的 GID 和注释(描述文本)。
期望的结果
这里的整个目标是获取在其 Notes 值中具有 #websiteprojecttemplate 的项目的 GID。我们需要找到该项目的 GID,然后将其输出,以便稍后在 Zapier 操作中使用该 GID。
体式任务 API
使用这个 API URL,我们可以看到返回项目数据(包括 GID 和 Notes)的 API 的输出。我相信这是 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;博士
我们如何更新当前代码,以便它可以遍历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");
}
推荐阅读
- python - 从 typeform 为 Python 创建 API
- angular - Angular post 方法没有收到来自 Spring Boot 应用程序的响应
- python - 将 YAML 转换为 JSON 时出错:yaml:第 3 行:未找到预期的密钥
- reactjs - React:如何重构它以防止整个重新渲染并将其封装到重要的组件中?
- elasticsearch - 数据操作的 API 命名约定
- django - 如何在 HTML 上显示作为类属性的对象列表 (ManyToMany)
- keep-alive - unix 域套接字(套接字系列 AF_UNIX)是否支持套接字选项 SO_KEEPALIVE?
- c# - 如何在用户 OnSignedIn 事件的启动中创建 Redis 缓存?
- c# - 执行 Yield return 会停止 Unity 中的协程
- ios - 催化剂 textview 插入符号颜色