0

我在 Dojo 1.6 中连接和链接延迟的 ajax 请求时遇到了一个小问题。代码看起来像

    login : function(data) {            
        var def = lang.hitch(this.authenticate, this.authenticate(data));
        console.log(def); // [I]
        return def;
    },

    authenticate : function(data) {
        require([ "dojo/Deferred", "dojo/request/xhr", "dojo/_base/lang",
                "dojox/encoding/digests/MD5" ], lang.hitch(this, function(Deferred, xhr,
                lang, MD5) {
            var data2send = lang.mixin(data, {
                action : "authenticate",
                password : "21232f297a57a5a743894a0e4a801fc3",
                userId : data.username
            });

            return xhr(this.handlerUrl, {
                handleAs : "json",
                method : "POST",
                sync : false,
                data : data2send
            });
        }));
    }

其中 login() 被调用。恕我直言,它应该返回一个延迟对象,该对象在 authenticate() 中的 ajax 请求完成后解析。因此,[I] 中的日志记录应该给我一个 Deferred-promise,但 Firebug 将返回值记录为 function()。我希望任何人都可以提供帮助。

提前致谢!

编辑:另一个问题是,为什么 def 成为对象,它由 lang.hitch 的第一个参数给出。例如,在日志上面的代码中给了我“function()”。当我将第一个参数更改为“this”时,日志给了我“this”-object(“Object {...}”)本身。我假设挂接机制不会影响返回值,但只会将范围挂接到第二个参数(即被调用函数)。我错了吗?!

4

1 回答 1

0

代码最终看起来像这样:

define([ "dojo/_base/lang", "dojo/_base/declare", "dojo/Deferred",
    "dijit/_Widget" ], function(lang, declare, Deferred) {
return declare("LoginController", null, {
    handlerUrl : "sessionHandler.php",
    constructor : function(kwArgs) {
        lang.mixin(this, kwArgs);
    },

    login : function(data) {
        def = new Deferred();
        auth = this.authenticate(data);
        auth.then(function(success) {
            if (success.success == true) {
                def.resolve(true);
            } else {
                def.resolve(false);
            }
        }, function(err) {
            def.resolve(false);
        });
        return def;
    },

    authenticate : function(data) {
        var def = new Deferred();
        require([ "dojo/request/xhr" ], lang.hitch(this, function(xhr) {
            var data2send = lang.mixin(data, {
                action : "authenticate",
                userId : data.userId
            });

            xhr(this.handlerUrl, {
                handleAs : "json",
                method : "POST",
                sync : false,
                data : data2send
            }).then(function(data) {
                def.resolve(data);
            }, function(err) {
                def.reject(err);
            });

        }));
        return def;
    }
});
});

如果没有在前面设置 Deferred,我就无法绕过 require 的异步调用。因此,Deferred 构造函数最初必须在定义语句中加载,因此我不需要在我的函数中异步地要求它。

于 2013-01-12T10:31:51.210 回答