2015-06-18 39 views
0

我理解分析承诺背后的理论(.then,.done,.when等),但我不知道如何执行它们。目前,我正在使用警报来迫使系统等待足够长的时间以履行承诺,但那是一种非常粗糙的做法。我将发布的代码完全符合我的要求。它创建一个表格,从数据库收集信息,并将其格式化到表格中。如果我拿出戒备(“迫使等待”);它不会工作,因为承诺还没有实现。我应该在哪里以及如何添加一些承诺处理程序以使其在没有警报的情况下工作?我尝试将for循环更改为do,然后添加。然后,但我无法让它不抛出错误,但是我很确定这是因为我格式化了错误的结构。任何帮助将不胜感激。谢谢!执行分析承诺

function billingReport(){ 
    var sDate = new Date(document.getElementById("startDate").value); 
    var table = document.getElementById("results1"); 
    var row, cell1, cell2, cell3, cell4; 
    var tableHeaderRowCount = 1; 
    var rowCount = table.rows.length; 
    for (var i = tableHeaderRowCount; i < rowCount; i++) { 
     table.deleteRow(tableHeaderRowCount); 
    } 
    Parse.Cloud.run("runReport", {sDate: sDate}, { 
     success: function(result){ 
      alert("Successfully retrieved " + result.length + " scores."); 
      for(var i = 0; i < result.length; i++){ 
       alert("forces a wait"); 
       Parse.Cloud.run("caseHelper", {id: result[i].attributes.customer.id, className: "User", attribute: "username"},{ 
        success: function(results){ 
         row = table.insertRow(i);  
         cell1 = row.insertCell(0); 
         cell2 = row.insertCell(1); 
         cell3 = row.insertCell(2); 
         cell4 = row.insertCell(3); 
         cell1.innerHTML = result[i-1].id; 
         cell2.innerHTML = result[i-1].attributes.title; 
         cell3.innerHTML = result[i-1].attributes.hoursWorked; 
         cell4.innerHTML = results; 
        }, 
        error: function(error){ 
         alert("Error gathering customer information: " + error.code + " - " + error.message); 
        } 
       }); 
       } 
     }, 
     error: function(error){ 
      alert("Error creating report :" + error.code + " - " + error.message); 
     } 
    }); 
} 

这里是我的这个功能云代码:

Parse.Cloud.define("runReport", function(request, response) { 
    var sDate = request.params.sDate; 
    var caseList = Parse.Object.extend("Cases"); 
    var query = new Parse.Query(caseList); 
    query.equalTo("status", "closed"); 
    query.greaterThanOrEqualTo("createdAt", new Date(sDate.toISOString())); 
    query.find({ 
     success: function(results){ 
      var q = results; 
      response.success(q); 
     }, 
     error: function(error){ 
      response.error("Failed to create query for report."); 
     } 
    }) 
}); 

Parse.Cloud.define("caseHelper", function(request, response) { 
    var id = request.params.id; 
    var className = request.params.className; 
    var attribute = request.params.attribute; 
    var list = Parse.Object.extend(String(className)); 
    var query = new Parse.Query(String(className)); 
    query.equalTo("objectId", id); 
    query.first().done(function(result){ 
     var a = result.get(attribute); 
     response.success(a); 
     }); 
}); 
+0

你从哪里运行'billingReport'?它与'runReport'在同一个文件中吗?从其他地方调用runReport吗?就像从Parse以外的应用或网站一样? – MayNotBe

回答

0

我可能是错的,但Parse.Cloud.run("caseHelper",可能会引起问题,所有这些都在异步运行,而不2可能的alert结果提前1结果并搞砸table.insertRow(i),也不知道[i-1]业务背后的原因,因为至少对于我的价值0,它不会工作。

我会建议你使用Promise.when并等待所有承诺插入行之前完成:

function billingReport(){ 
    var sDate = new Date(document.getElementById("startDate").value); 
    var table = document.getElementById("results1"); 
    var row, cell1, cell2, cell3, cell4, scores; 
    var tableHeaderRowCount = 1; 
    var rowCount = table.rows.length; 
    for (var i = tableHeaderRowCount; i < rowCount; i++) { 
     table.deleteRow(tableHeaderRowCount); 
    } 
    Parse.Cloud.run("runReport", {sDate: sDate}).then(function(data){ 
     scores = data; 
     console.log("Successfully retrieved " + scores.length + " scores."); 
     return Parse.Promise.when(scores.map(function(score){ 
      return Parse.Cloud.run("caseHelper", {id: score.attributes.customer.id, className: "User", attribute: "username"}); 
     })); 
    }).then(function(results){ 
     for(var i = 0; i < scores.length; i++){ 
      row = table.insertRow(i);  
      cell1 = row.insertCell(0); 
      cell2 = row.insertCell(1); 
      cell3 = row.insertCell(2); 
      cell4 = row.insertCell(3); 
      cell1.innerHTML = scores[i].id; 
      cell2.innerHTML = scores[i].attributes.title; 
      cell3.innerHTML = scores[i].attributes.hoursWorked; 
      cell4.innerHTML = results[i];      
     } 
    }).fail(function(err){ 
     console.log("Error creating report :" + err); 
    }); 
} 
+0

我相信这是i-1业务,因为我没有正确处理异步。这是我能够正确检索所有项目的唯一方法,即使逻辑没有意义。我想,当它检索到i时,它已经增加了,所以我必须减少1来抵消这个值。我会执行你的修复,看看会发生什么,我会让你知道结果。 –

+0

它现在没有警报,所以在技术上你的答案是正确的,但它并不完全符合预期。 caseHelper返回单个字符串值,而不是数组。所以结果[i]只是返回字符串的第一个字母。将其更改为只是结果会给出整个字符串,但每次都是相同的字符串。我认为解决这个问题的最简单方法是改变案例Helper去推出一个数组而不是单个字符串值,然后结果[i]可以正常工作 –