1

我有这个代码:

var async = require("async");

module.exports = function(vars){

    return {

        a: function(){
            console.log("a()");
        },

        b: function(){

            var self = this;

            async.series([
                function(callback){
                    ...
                    callback();
                },
                function(callback){
                    ...
                    callback();
                }
            ], function(){
                self.a(); // <------- err
            });
        }

    }
}

然后我将 b 称为:

var test = require("./test.js")({});
test.b();

但我收到了这个错误:Object #<Object> has no method 'a'。为什么?

编辑:

抱歉,此代码实际上运行良好,但我在生产中的代码中遇到了该错误。

这个例子(可以正常工作)和我的代码(不能正常工作)的唯一区别是我的演示代码是直接调用的:

var test = require("./test.js")({});
test.b();

而我的生产代码是从另一个库调用的:

var my_code = require("./something.js")({});
imap_notify.on_new_mail(my_code.my_func);
4

2 回答 2

1

问题是外部库可能会更改上下文(使用 调用您的函数.bind(this))。

您可以将对象存储在一个变量中并直接调用它

module.exports = function(vars){

    var obj =  {

        a: function(){
            console.log("a()");
        },

        b: function(){

            // var self = this; // useless now

            async.series([
                function(callback){

                    callback();
                },
                function(callback){

                    callback();
                }
            ], function(){
                obj.a(); // <--- now it works
            });
        }

    };

    return obj;
}
于 2013-09-27T12:48:58.083 回答
0

试试这个,不知道是否有效

var async = require("async");

var Item = function(){
    self= this;

    self.a= function(){
        console.log("a()");
    },

    self.b= function(){



        async.series([
            function(callback){
                ...
                callback();
            },
            function(callback){
                ...
                callback();
            }
        ], function(){
            self.a(); // <------- err
        });
    }
}



module.exports = function(){

    return new Item();

}
于 2013-09-27T09:25:44.927 回答