Javascript在运行时修改功能

时间:2012-06-29 18:36:55

标签: javascript

在此输入代码我有以下代码

function a(){alert("a");}

我想创建一个函数b作为

function b(){alert("a"); alert("b");}

我的方法就像

var b = a + alert("b");

这当然行不通。但我想知道是否有某种图书馆支持这一点。

编辑:也许我需要描述我的场景,以便更清楚我想要实现的目标。

我正在使用async.js库来处理多个异步调用。我的代码看起来像

var values = {};
...
function all() {
    var allDfd = $.Deferred();
    async.parallel(
            [function (callback) {
                remoteCall(function (result) {
                    values.v1 = result;
                    callback(null, 'one');
                });
            },
            function (callback) {
                remoteCall(function (result) {
                    values.v2 = result;
                    callback(null, "two");
                });
            },
            function (callback) {

                remoteCall(function (result) {

                    values.v3 = result;
                    callback(null, "three");
                });
            }], function (err, results) {
                allDfd.resolve();
            });
    return allDfd.promise();
}

显然,有很多重复的代码困扰着我。所以我的想法是创建一个函数asyncCall来执行样板任务。这个想法是

   var values = {};
...
function all() {
    var allDfd = $.Deferred();
    function getAsyncCall (func, innerCallback, callback) {
        return function asyncCall(func, innnerCallback, callback){
            func(innerCallback + callback(null));  // combine innerCallBack and callback code
        }
    }

    async.parallel(
            [getAsyncCall(remoteCall, function(result){values.v1=result;},callback),
             getAsyncCall(remoteCall, function(result){values.v2=result;},callback),
             getAsyncCall(remoteCall, function(result){values.v3=result;},callback),
            ], function (err, results) {
                allDfd.resolve();
            });
    return allDfd.promise();
}

评论的内容正是我在思考的问题。我正在尝试创建一个结合内部和外部回调的新函数。

2 个答案:

答案 0 :(得分:4)

你可以做到

var b = function() { a(); alert('b'); }

答案 1 :(得分:1)

你可以写:

var a=function(){alert("a");}

var b=function(){a(); alert("b");}

为了更进一步,你甚至可以编写一个完整的函数组合函数:

function compose( functions ) {
   return function(){ 
      for(var i=0; i!=functions.length; ++i) {
        functions[i]();
      }
   };
}

var c=compose( [a, function(){ alert("b"); }] );

(在http://jsfiddle.net/xtofl/Pdrge/工作时查看)