Невозможно получить возвращаемое значение функции из модуля - PullRequest
0 голосов
/ 06 июня 2019

Из маршрута я хочу назвать функцию, которая принадлежит модулю:

    const fs = require('fs');
    var path = require('path');
    var express = require('express');
    var async = require('async');
    var utils = require('./utils'); // this is the module
    var router = express.Router();
    var mysql = require('mysql');
    var connexion = mysql.createConnection({
                                                host: "localhost",
                                                user: "root",
                                                password: "root",
                                                database: "george"
                                            });

router.post('/insertAxes', function(req, res) {
    fs.readFile(path.join(__dirname, '../config/Bd_region_zone_juin19.geojson'), (err, data) => {
        if (err) throw err;
        let json = JSON.parse(data);
        var features = json.features;
        var axes = [];
        async.eachOf(features, function(item, position, cb) {
                                var featureJSON = features[position];
                                var propertyJSON = featureJSON.properties;
                                var axeLib = propertyJSON.Axes2019;
                                var regionId = utils.getRegionIdFromLib(propertyJSON.lib_rc);
                                var geometryJSON = featureJSON.geometry;
                                var coordinates = geometryJSON.coordinates;
                                var polygone = 'ST_GeomFromGeoJSON(\'{"type":"MultiPolygon", "coordinates":'+coordinates+'}\')';
                                axes.push([regionId]);
                                cb();
                            }, function() {
                                connexion.query("insert into axe(axe_libelle) values ?", [axes], (err, result) => {
                                    if (err) {
                                        throw err;
                                    }
                                });
                            });
        res.send(json);
    });
});

Вот модуль:

var async = require('async');
var mysql = require('mysql');
var connexion = mysql.createConnection({
                                            host: "localhost",
                                            user: "root",
                                            password: "root",
                                            database: "george"
                                        });

/**
 * Permet de savoir si un élément est dans un tableau contenu dans un tableau
 * @param {array} tabData tableau de tableaux
 * @param {number} positionElement position de l'élément dans le second tableau
 */
exports.isDataInArrayOfArray = function (tabData, positionElement, element) {
    var tmp = [];
    async.eachOf(tabData, function(item, position, cb) {
        var dataArray = tabData[position];
        tmp.push(dataArray[positionElement]);
        cb();
    }, function() {});
    return tmp.includes(element);
};

/**
 * Permet de récupérer la clé primaire d'une région selon la région libellé
 * @param {string} regionLib Libellé de la région
 */
exports.getRegionIdFromLib = function (regionLib) {
    var ret = 0;
    connexion.query("select region_id from region where region_libelle = ? limit 1", [regionLib], (err, rows) => {
        if (err) {
            throw err;
        }
        ret = rows[0].region_id;
        console.log(ret);
    });
    return ret;
};

console.log отображает значения, но я получаю 0 при достижении аффекта var regionId = utils.getRegionIdFromLib(propertyJSON.lib_rc);! Так что не так?

1 Ответ

1 голос
/ 06 июня 2019

Ваш вызов connexion.query является асинхронным, поэтому функция getRegionIdFromLib возвращается до завершения запроса.

Следовательно, вы получаете начальное значение 0.

Возможно, вы могли бы принятьвызовите функцию и передайте ей regionId, когда будете готовы:

exports.getRegionIdFromLib = function (regionLib, callback) {
  var ret = 0;
  connexion.query("select region_id from region where region_libelle = ? limit 1", [regionLib], (err, rows) => {
    if (err) {
      throw err;
    }
    ret = rows[0].region_id;
    console.log(ret);
    callback(ret);
  });
};

... а затем:

async.eachOf(
  features,
  function(item, position, cb) {
    var featureJSON = features[position];
    var propertyJSON = featureJSON.properties;
    var axeLib = propertyJSON.Axes2019;
    var geometryJSON = featureJSON.geometry;
    var coordinates = geometryJSON.coordinates;
    var polygone = 'ST_GeomFromGeoJSON(\'{"type":"MultiPolygon", "coordinates":'+coordinates+'}\')';

    // Move "cb" call inside the callback
    utils.getRegionIdFromLib(propertyJSON.lib_rc, function(regionId) {
      axes.push([regionId]);
      cb();
    });
  },
  function() {
    connexion.query("insert into axe(axe_libelle) values ?", [axes], (err, result) => {
      if (err) {
        throw err;
      }
    });
  });

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...