我看了this并试图实现我的功能,以便数据不会改变,但它并没有与我合作。
我有一个对象数组,我将它们逐个发送到另一个函数,以添加数据。
queries.first(finalObject.sectionProjects[i]);
对于sectionProjects
中的每一个,都有一个变量achievements
,其中包含一个空数组。
将每个sectionProject发送到the queries.first
函数后,我重新分配成就
finalObject.sectionProjects[i].achievements = something else
当我从queries.first函数返回时,我丢失了我添加的数据。 我做错了吗?
这里的功能是:
module.exports = {
first:function(aProject) {
// Latest achievements
var query =
" SELECT ta.description, ta.remarks, ta.expectedECD " +
" FROM project pr, task ta, milestone mi " +
" WHERE pr.ID = mi.project_ID AND mi.ID = ta.milestone_ID " +
" AND ta.achived = ta.percent AND pr.ID = " + aProject.project_id +
" ORDER BY pr.expectedECD " +
" LIMIT 5;"
;
var stringified = null;
pmdb.getConnection(function(err, connection){
connection.query(query, function(err, rows){
if(err) {
throw err;
}else{
var jsonRows = [];
for( var i in rows) {
stringified = JSON.stringify(rows[i]);
jsonRows.push(JSON.parse(stringified));
}
connection.release();
aProject.achievements = jsonRows;
upcomingTasks(aProject);
}
});
});
}
}
这是pmdb.js:
var mysql = require("mysql");
var con = mysql.createPool({
host: "localhost",
user: "user",
password: "password",
database: "database"
});
module.exports = con;
这是调用queries.first:
的主要函数// ...Code...
//Number of section projects
var len = jsonRows.length;
console.log("Number of section projects: " + len);
var internal_counter = 0;
function callbackFun(i){
(finalObject.sectionProjects[i]).achievements = [];
queries.first(finalObject.sectionProjects[i]);
if(++internal_counter === len) {
response.json(finalObject);
}
}
var funcs = [];
for (var i = 0; i < len; i++) {
funcs[i] = callbackFun.bind(this, i);
}
for (var j = 0; j < len; j++) {
funcs[j]();
}
答案 0 :(得分:1)
阅读That回答两次。对象充当标量原始属性的包装器。您正在将对象传递给“queries.first”函数。
编辑示例代码
Unauthorized
Error 401
这不是问题。像这样改变它。 “comingTasks”不是回调函数。在项目
中分配成就后执行