我有一个像这样的javascript
function one (var1, var2){
var var3= var1+var2;
return var3;
}
function two( var4, var5){
var var6=var4*var5;
return var6;
}
function three(var7, var8){
var9=var7/var8;
return var9;
}
var first = one(2, 4);
var second= two(first, 8);
var third= three(second, 9);
我希望所有功能都是独立的,因为它们每个都像处理不同操作的模块一样。所以我不想使用回调,我已经尝试过
$.ajax(first = one(2,4))
.then({second=two(first, 8)})
.then(three(second,9))
我也尝试过
$.ajax()
.then(function(first=one(2,4){
return first;
})
.then(function(second=two(first,4){
return second;
})
我也尝试过
$.ajax({
first:one(2,4),
second:two(first,4),
third:three(second,9),
})
.then(function(first=one(2,4){
return first;
})
.then(function(second=two(first,4){
return second;
})
这听起来很有趣,但我什至尝试过
var third= three(two(one(2, 4), 8), 9);
在许多其他事物中。
所有这些都显示操作是通过第一个功能和其他功能进行的,但是它并没有给我上一个功能的结果
这是对上述内容的更新。 修改
我不想在其他功能中使用promise,因为其他一些功能也将调用这些功能,而他们并不期望promise而是有效数据
function modifyData(details){
for(var x=0 ;x<array.length;x++){
//this would do a massive loop which would
//return a json string that would be
}
}
function tableFunction(url, tableNameVar){
//json fields
var details=[];
details[0] = 'name';
details[1] = 'sex';
details[2] = 'eye_color';
details[3] = 'height';
details[4] = 'body_built';
var jsonData='';
var main = "";
$(document).ready(function(){
$('#'+tableNameVar+'').dataTable({
destroy: true,
data: JSON.parse(extraFunctionProcess(modifyData(details),details)),
columns:[
{title: "Name", data:"name"} ,
{title: "Gender", data:"sex"} ,
{title: "Eye color", data:"eye_color"} ,
{title: "Height", data:"height"} ,
{title: "Body built", data:"body_built"}
]
});
});
}
我想处理数据并将其放入表中。如果传递数据,则extraFunctionProcess已起作用 直接进入数据字段,而无需将其放入ModifyData函数中。 而不是上面的
data: JSON.parse(extraFunctionProcess(fullData,details))
这有效,但是由于我所做的修改,它在我的浏览器控制台中显示了一个错误 在extraFunctionProcess内部未定义。
我只是将代码简化为我现在上线的
答案 0 :(得分:0)
我实际上找到了解决问题的方法。 ModifyData函数就是有问题的那个。返回值在另一个函数中。 以下内容
function modifyData(details){
for(var x=0 ;x<array.length;x++){
//this would do a massive loop which would
//return a json string that would be inside a function
}
}
function modifyData(details){
for(var x=0 ;x<array.length;x++){
return functionName(callback to be done);
//this would do a massive loop which would
//return a json string that would be
}
}