通过引用进行的Javascript调用不起作用

Javascript call by reference not working

本文关键字:Javascript 调用 不起作用 引用      更新时间:2023-09-26

我读了这篇文章,并尝试实现我的函数,这样数据就不会变回来,但它对我不起作用。

我有一个对象数组,在其中我将它们一个接一个地发送到另一个函数,以添加数据。

queries.first(finalObject.sectionProjects[i]);

对于每个sectionProjects,都有一个变量achievements,其中有一个空数组。

在将每个部分Project发送到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;

这是调用查询的主要函数。第一个:

// ...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]();
}           

读两遍这个答案。对象充当标量基元属性的包装器。您正在将对象传递给"querys.first"函数。

参见本对象参考问题

为样本代码编辑

    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)
            }
        });
    });

这不是问题。这样改吧。"upcomingTasks"不是回调函数。它是在分配aProject 中的成就后执行的