从函数传递一个数组,并在其他函数中全局使用它
Pass an array from function and use it globally in other function?
我在一个函数中有一个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];
}
- Jquery未定义函数正在停止其他操作
- 执行php函数的onclick事件的其他替代方案
- 如何在.js函数中检索来自其他模板的表单的目标值
- 对其他函数使用匿名函数's参数
- 创建要在其他函数中使用的全局变量
- 调试一个简单的jQuery函数;想知道是否与其他代码冲突
- 在Meteor中如何将数据从函数内部复制到其他模板
- 在Jquery调用之间添加其他函数
- 使用一个Javascript函数提交多个表单可以在FF中工作,而不需要其他浏览器
- Mocking console.log()/MOCHA测试框架中的任何其他函数
- 如何从ipify函数返回ip地址,以便在其他函数中使用
- 如果没有其他函数链接到promise,则默认行为
- Javascript创建函数,以便在其他函数之间共享变量
- AngularJS:如何与其他控制器共享作用域函数和变量
- Firefox扩展开发:如何在内容脚本中创建一个全局函数,以便其他加载的脚本文件可以访问它
- 使通过函数加载的JSON可用于其他函数
- 如何使用 javascript 函数取决于是否其他
- 如何在 JavaScript 中访问函数中的其他属性值作为对象属性值
- 有没有办法将其他参数传递给 scrollTarget 回调函数
- 如何在创建的字段上应用 .change 函数 b 其他字段的 .change 函数