如何多次在数组中存储相同的数据?

问题描述 投票:0回答:1

我从this api获取音频URL和一些文本。直到现在我能够使用webhook在对话框流程上获得此响应。

现在我需要多次获取相同的数据。例如,直到现在,如果我要播放音频,它提供url 1次。现在我希望它多次返回URL,例如当我要求它播放音频2次或100次时,它应该相应地给出URL。

URL必须以与我相同的方式存储在数组中。

我正在将包含“url”,“title”和“type”的对象推送到名为“messages”的数组中。它应该被推到特别没有。我使用'times'变量指定的时间。

这是我尝试过的。请检查循环是否正确放置?没有循环这个函数很好,只返回一次数据。如果需要任何其他细节,请告诉我。

static readAyahOfSurahMultipleTimes = async (agent: any) => {


           const params = agent.parameters
           console.log("params: ", params)

           let surahApi: any = await http.get(`http://api.alquran.cloud/v1/ayah/${params.surahName}:${params.ayahNumber}/editions/ar.alafasy,en.asad`);

           var ayahs: any = surahApi["data"];  
           console.log("ayahs", ayahs);

           let payload = {
               "web": {     
                   "messages": []
               }
           }
           try {
               ayahs.forEach(function (item) {
                   for(var i=0;i<params.times;i++){
                   payload.web.messages.push({                              
                       "url": item.audio,
                      // "title": item.text,
                      "title": surahApi["data"][0]["text"],
                       "type": "audio",
                   }) 
                }
               });
               console.log("payload", payload);
               console.log("payload.web.messages",payload.web.messages);


               raw.response.send({

                   "fulfillmentText": `Ayah number ${params.ayahNumber} of surah number ${params.surahName} is being played`,   
                   "payload": payload
               })
               return;
           } catch (e) {
               console.log("error in catch block", e);
               raw.response.send({
                   "fulfillmentText": `response from catch`
               })
           }
       }

完成反应enter image description here

typescript loops dialogflow array-push
1个回答
1
投票

变量ayahs是一个包含两个对象的数组,只有第一个对象包含音频url(尝试在浏览器中打开http://api.alquran.cloud/v1/ayah/2:286/editions/ar.alafasy,en.asad来检查响应)。您当前正在遍历这两个对象,并将两个对象的音频URL附加到数组对象的url属性,之所以它只运行一次是因为音频网址仅存在于第一个对象上。您需要消除第一个forEach循环并通过ayahs数组的第一个元素访问音频。

static readAyahOfSurahMultipleTimes = async (agent: any) => {

     const params = agent.parameters

     let surahApi: any = await http.get(`http://api.alquran.cloud/v1/ayah/${params.surahName}:${params.ayahNumber}/editions/ar.alafasy,en.asad`);

     var ayahs: any = surahApi["data"];  


     let payload = {
        "web": {     
            "messages": []
        }
     }

     try {
        let ayah: any = ayahs[0];
        let audio:string = ayah.audio;

        for(var i=0; i<params.times; i++){
           payload.web.messages.push({                              
              "url": audio,
              "title": surahApi["data"][0]["text"],
              "type": "audio",
           }) 
        }          

        raw.response.send({
           "fulfillmentText": `Ayah number ${params.ayahNumber} of surah number ${params.surahName} is being played`,   
           "payload": payload
        })

        return;
     } 
     catch (e) {
       raw.response.send({
          "fulfillmentText": `response from catch`
        })
     }
  }

现在我认为你通过复制消息数组上的数据所做的事情毫无意义,你可以简单地添加一个属性,用于音频需要在有效负载对象中重复的次数,然后在客户端上配置它使用此变量重复多次。

payload.web.messages.push({                              
   "url": audio,
   "title": surahApi["data"][0]["text"],
   "repititionTimes": params.times
   "type": "audio"
})

这样您就不必使用循环,也不会发送不必要的有效负载。

© www.soinside.com 2019 - 2024. All rights reserved.