繁体   English   中英

Google App脚本-函数返回未定义

[英]Google App Script - Function Returning Undefined

我正在尝试调用给定Slack Workspace和频道名称时获取频道ID的函数。 我可以在函数中获得正确的结果,但是当我尝试在其他地方调用该函数时,它返回的是未定义的。

获取频道ID的函数

 //GET CHANNEL ID FROM LIST OF ALL CHANNELS IN WORKSPACE function getChannelID(workspaceName, pageLimit, channelName, nextCursor){ var channelListResponseURL = 'https://slack.com/api/conversations.list'; var payload = { 'limit': pageLimit, 'types': 'public_channel, private_channel', 'cursor' : nextCursor }; var options = createURLargs(workspaceName, payload); var channelListResponse = UrlFetchApp.fetch(channelListResponseURL, options); var channelListJson = channelListResponse.getContentText(); var channelListData = JSON.parse(channelListJson); //iterate through each channel in the returned JSON object and sets the channel ID for the one matching the channelName for (var i in channelListData.channels){ if(channelListData.channels[i].name == channelName){ var channelID = channelListData.channels[i].id; Logger.log('FOUND CHANNEL ID: '+ channelID); return channelID;// IF CHANNEL ID FOUND, THEN EXIT getChannelID FUNCTION AND RETURN CHANNEL ID } } // IF NO CHANNEL ID IS FOUND, THEN CHECK TO SEE IF PAGINATION IS IN EFFECT, UPDATE CURSOR, AND RERUN getChannelID FUNCTION if (channelListData.response_metadata.next_cursor && channelListData.response_metadata.next_cursor != ""){ nextCursor = channelListData.response_metadata.next_cursor; getChannelID(workspaceName, pageLimit, channelName, nextCursor); } else { // IF CHANNEL PAGINATION IS NOT IN EFFECT, OR REACHED LAST PAGE AND NO RESULT IS FOUND return 'No Channel Found in Workspace'; } } 
`

我可以在记录器中清楚地看到“ FOUND CHANNEL ID:CXXXXXX”字符串,因此我确定它可以正确找到它。

但是,当我从主函数调用此getChannelID时,它返回的是未定义的。

  var channelID = getChannelID(workspaceName, pagLimit, channelName, nextCursor); Logger.log(channelID); 

奇怪的是,当未对来自Slack的JSON对象进行分页时,这似乎可行,但是当对结果进行分页时,我似乎变得不确定。

任何想法为什么返回的结果都不确定,即使它在函数中也有效?

我认为在您的递归函数中,不会返回该值。 那么如何修改呢?

来自:

if (channelListData.response_metadata.next_cursor && channelListData.response_metadata.next_cursor != ""){
  nextCursor = channelListData.response_metadata.next_cursor;
  getChannelID(workspaceName, pageLimit, channelName, nextCursor);
} else { 
  // IF CHANNEL PAGINATION IS NOT IN EFFECT, OR REACHED LAST PAGE AND NO RESULT IS FOUND
  return 'No Channel Found in Workspace';
}

至 :

if (channelListData.response_metadata.next_cursor && channelListData.response_metadata.next_cursor != ""){
  nextCursor = channelListData.response_metadata.next_cursor;
  return getChannelID(workspaceName, pageLimit, channelName, nextCursor); // Modified
} else { 
  // IF CHANNEL PAGINATION IS NOT IN EFFECT, OR REACHED LAST PAGE AND NO RESULT IS FOUND
  return 'No Channel Found in Workspace';
}

注意 :

  • channelListData.response_metadata.next_cursor && channelListData.response_metadata.next_cursor != ""为true时,不返回任何值。 所以我加了return

如果还不能解决问题,请告诉我。 我想修改它。

添加 :

据我了解,当运行递归函数时,过程返回到运行的行。 为了确认这一点,我准备了3个示例函数。

功能1
function foo3(value) {
  if (value == "") {
    foo3("bar");
  }
  return "ok";
}
功能2
 function foo2(value) { if (value == "") { return foo2("bar"); } else { return "ok"; } } 
功能3
 function foo3(value) { if (value == "") { foo3("bar"); } return "ok"; } 

当这些功能按如下方式运行时,

 var res1 = foo1(""); var res2 = foo2(""); var res3 = foo3(""); 

res1res2res3分别是undefinedokok

暂无
暂无

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

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