为了账号安全,请及时绑定邮箱和手机立即绑定

API函数被调用两次导致重复

API函数被调用两次导致重复

梵蒂冈之花 2022-12-09 16:27:24
我正在尝试向远程服务器发送获取 API 请求。响应非常好,正如我想要的那样。我正在尝试将响应存储在一个表中。但这里的问题是该processRequest()函数被调用了两次,这会产生重复的结果。我正在使用的警报也显示了两次。document.getElementById("ndviHsearch").onclick = function getndviHdata(){   var ndvihconvdataTime=[];   var ndvihStd=[];   var ndvihp25=[];   var ndvihmin=[];   var ndvihmax=[];   var ndvihmedian=[];   var ndvihmean=[];   var ndvihp75=[];   var ndviHfidValue = document.getElementById("ndviHfid").value;   var ndviHstartDateValue = document.getElementById("ndviHstartDate").value;   var ndviHendDateValue = document.getElementById("ndviHendDate").value;   table = document.getElementById("ndviHtable");   const xhr = new XMLHttpRequest();   ndviHstartDateValue = new Date(ndviHstartDateValue).getTime() / 1000;   ndviHendDateValue = new Date(ndviHendDateValue).getTime() / 1000;   xhr.open("GET","https://api.agromonitoring.com/agro/1.0/ndvi/history?polyid="+ndviHfidValue+"&start="+ndviHstartDateValue+"&end="+ndviHendDateValue+"&appid=APIKEY");   xhr.setRequestHeader("Content-Type","application/json");   xhr.send();   xhr.onreadystatechange = processRequest;   function processRequest(e) {     if (xhr.status==200){       response = JSON.parse(xhr.responseText);       alert (response.length);       for (var i=0; i<response.length; i++){         var dt = response[i].dt;         // Unixtimestamp         var unixtimestamp = dt;         // Months array         var months_arr = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec'];         // Convert timestamp to milliseconds         var date = new Date(unixtimestamp*1000);            var year = date.getFullYear();         var month = months_arr[date.getMonth()];         var day = date.getDate();         var hours = date.getHours();         var minutes = "0" + date.getMinutes();         var seconds = "0" + date.getSeconds();         }    }    
查看完整描述

1 回答

?
拉风的咖菲猫

TA贡献1995条经验 获得超2个赞

您还需要检查 readyState 值(xhr.readyState == 4 && xhr.status == 200)

函数 xhr.onreadystatechange = processRequest;将在每次 xhr 状态更改时执行,您需要检查是否readyState == 4还有status  == 200,然后执行您的操作。


查看完整回答
反对 回复 2022-12-09
  • 1 回答
  • 0 关注
  • 158 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号