Javascript返回函数在另一个函数中

时间:2018-09-26 20:17:06

标签: javascript function variables return

我有一个像这样的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内部未定义。

我只是将代码简化为我现在上线的

1 个答案:

答案 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 
    }
 }