从函数传递一个数组,并在其他函数中全局使用它

Pass an array from function and use it globally in other function?

本文关键字:函数 其他 全局 数组 一个      更新时间:2023-09-26

我在一个函数中有一个C()函数B(),其中有另一个函数A();函数CCD_ 4在下拉列表的每次改变时运行。B()函数生成一个二维数组,C ()函数取二维数组并生成另一个一维数组。这就是生成的数组v [],问题是如何在C()中传递数组,并在A()的同一级别声明的名为calculate()的函数中全局使用它?

我听说全局变量不好,我应该使用什么替代解决方案?

A(){
  B(){
    C(){
      var v = new Array();
        .....
        .....
        v[i] = disciplines[i].nom;
       }
     }
   }
Calculate(array,id){
  var result = v[i];
}

我使用的是codeigniter,在script2中,我有一个函数,它将计算要支付的金额,并将其插入到id为salle_montant_paye的输入中,这里我缺少两个变量:qp(porcentage%示例=0.5)和tarif(每月金额)。所以我需要把它们从脚本一传给脚本二。

在脚本中,对于salle(gym)的每一个选择,我都有一个规程(sport),对于每个规程,我有一个qp(pourcentage)和tarif(amount)。因此,由循环生成的数组qp[]和tarif[]包含qp和tarif by id的值,例如,如果我在名为Zimgym的健身房选择足球(其指数为2),我必须每月支付120,社会将为我支付一半(0.5)。这些值存储在qp[i]和tarif[]中,因此,我需要将它们传递给函数$('#professions').change(function(){var a=$(this).fund('option:selected').attr('value');它们具有规程a=2的索引,我将使用该索引来检索qp和tarif的值,然后将它们传递到脚本2以计算要支付的金额。

我的代码:

脚本1

function qp(qp, id) {
    var qpresult = qp[id];
}
function tarif(tarif, id) {
    var tarifresult = tarif[id];
}
$(document).ready(function () {
    $('#salle').change(function () {
        //any select change on the dropdown with id salle trigger this code        
        $("#disciplines > option").remove(); //first of all clear select items
        var salle_nom = $('#salle').val(); //here i'm taking salle id of the selected one.
        $.ajax({
            type: "POST",
            url: "http://localhost/public_html/admin/dropdown_salle/get_cities/" + salle_nom,
            //here i'm calling our user controller and get_disciplines method with the salle_id
            dataType: "json",
            success: function (disciplines) //we're calling the response json array 'disciplines'
            {
                var discipline = new Array();
                var qp = new Array();
                var tarif = new Array();
                for (i = 0; i < disciplines.length; ++i) {
                    // Now i got 3 arrays from the two dimentional 
                    //array from the db. one for 'disciplines',
                    // one for 'qp_agent' = (pourcentage a payé pour l'agent), 
                    //and the last for 'tarif'(tarif par mois de la cette discipline dans la salle choisi).
                    discipline[i] = disciplines[i].discipline + ' pour ' + disciplines[i].categorie_tarif;
                    qp[i] = disciplines[i].qp_agent;
                    tarif[i] = disciplines[i].tarif;
                }
                $.each(discipline, function (id, value)
                    //here i'm doing a foeach loop round each value
                    //with id as the key and value as the value
                    {
                        var opt = $('<option />');
                        // here i'm creating a new select option with for each value
                        opt.val(id);
                        opt.text(value);
                        $('#disciplines').append(opt);
                        //here i will append these new select options to a dropdown with the id 'disciplines'
                    });
            }
        });
    });
    var qp = new Array();
    // here on change disciplines i got the disciplines id, i will
    //use it to have 'qp' value and the 'tarif' value from qp[]
    //and tarif[] that correspond on discipline selected
    $('#disciplines').change(function () {
        var a = $(this).find('option:selected').attr('value');
        //here i retrieve the qp and tarif value corresponds to my 'discipline' choosen.
        var qp = qp(qp, a);
        var tarif = tarif(tarif, a);
    });
});
 // in the end i must pass thes 2 variables qp and tarif to 
 //the seconde script in te same page that calculate the amount to be paid 

脚本2

 function insertText(elemID) {
        var datestart = document.getElementById('date3');
        var dateend = document.getElementById('date4');
        var start = datestart.value;
        var end = dateend.value;
        var date1 = new Date(start);
        var date2 = new Date(end);
        var timeDiff = Math.abs(date2.getTime() - date1.getTime());
        var diffDays = Math.ceil(timeDiff / (1000 * 3600 * 24));
        var diffMonths = Math.round(diffDays / 30);
        var qp_variable = qp; // ici je doit affecter la valeur de qp passé a qp_variable
        var tarif_variable = tarif; // ici je doit affecter la valeur de qp passé a qp_variable
        var finalresult = diffMonths * qp_variable * tarif_variable;
        document.getElementById("salle_montant_paye").value = finalresult;
        //Now i get the js variable inside my input element.
    }
$(document).ready(function () {
var app = {}, 
    app.qp = [],
    app.tarif = [];
$('#salle').change(function () {
    //any select change on the dropdown with id salle trigger this code        
    $("#disciplines > option").remove(); //first of all clear select items
    var salle_nom = $('#salle').val(); //here i'm taking salle id of the selected one.
    $.ajax({
        type: "POST",
        url: "http://localhost/public_html/admin/dropdown_salle/get_cities/" + salle_nom,
        //here i'm calling our user controller and get_disciplines method with the salle_id
        dataType: "json",
        success: function (disciplines) //we're calling the response json array 'disciplines'
        {
            var discipline = [];                                                                           for (i = 0; i < disciplines.length; ++i) {
                // Now i got 3 arrays from the two dimentional 
                //array from the db. one for 'disciplines',
                // one for 'qp_agent' = (pourcentage a payé pour l'agent), 
                //and the last for 'tarif'(tarif par mois de la cette discipline dans la salle choisi).
                discipline[i] = disciplines[i].discipline + ' pour ' + disciplines[i].categorie_tarif;
                app.qp[i] = disciplines[i].qp_agent;
                app.tarif[i] = disciplines[i].tarif;
            }
            $.each(discipline, function (id, value)
                //here i'm doing a foeach loop round each value
                //with id as the key and value as the value
                {
                    var opt = $('<option />');
                    // here i'm creating a new select option with for each value
                    opt.val(id);
                    opt.text(value);
                    $('#cities').append(opt);
                    //here i will append these new select options to a dropdown with the id 'disciplines'
                });
        }
    });
});
// here on change disciplines i got the disciplines id, i will
//use it to have 'qp' value and the 'tarif' value from qp[]
//and tarif[] that correspond on discipline selected
$('#disciplines').change(function () {
    var a = $(this).find('option:selected').attr('value');
    //here i retrieve the qp and tarif value corresponds to my 'discipline' choosen.
    var qpValue = qp(qp, a);
    var tarifValue = tarif(tarif, a);
});
function qp(qp, id) {
   if (qp.indexOf(id) !== -1) {
       return qp[id]; 
   }
   return '';
}
function tarif(tarif, id) {
   if (tarif.indexOf(id) !== -1) {
       return tarif[id]; 
   }
   return '';
}
});

好吧,您可以简单地将v作为参数从C传递到Calculate函数,如下所示:

A(){
  B(){
    C(){
      var v = new Array();
      .....
      .....
      v[i] = disciplines[i].nom;
      Calculate(v, i);
    }
  }
}
Calculate(array, id){
  var result = array[id];
}