从JavaScript函数返回结果

时间:2013-02-17 16:43:11

标签: javascript function kaltura

我是JavaScript的新手,我希望有人可以帮助我理解如何修改下面的函数,以便在调用时正确返回结果。代码当前有效,并且在生成会话字符串后调用handleResults函数。我想要做的是修改generateSessionString函数,以便它返回会话字符串,而不是将其传递给handleResults。任何人都可以就我如何做到这一点给出建议吗?

function generateSessionString(){
var cb = function (success, results){
        if(!success)
        alert(results);

        if(results.code && results.message){
        alert (results.message);
        return;
        }
        handleResults(results);

    };

    var config = new KalturaConfiguration(gPartnerID);
    config.serviceUrl = gServiceURL;
    var client = new KalturaClient(config);
    var partnerId = gPartnerID;
    var userId = gUserName;
    var password = gPassWord;
    var expiry = gExpiry;
    var privileges = gPrivileges;
    var result = client.user.login(cb, partnerId, userId, password, expiry, privileges);
    return result;
}

function handleResults(ks){
KalturaSessionString = ks;
}

2 个答案:

答案 0 :(得分:1)

如果您想以同步方式编写它(它仍然是异步代码),您可以尝试承诺(在此示例中我使用了jQuery)

  function generateSessionString(){
           var dfd = new jQuery.Deferred();
           var cb = function (success, results){
               if(!success)
                   dfd.fail(results);

               if(results.code && results.message){
                   dfd.fail (results.message);
                   return;
               }
               dfd.resolve(results);

           };

           var config = new KalturaConfiguration(gPartnerID);
           config.serviceUrl = gServiceURL;
           var client = new KalturaClient(config);
           var partnerId = gPartnerID;
           var userId = gUserName;
           var password = gPassWord;
           var expiry = gExpiry;
           var privileges = gPrivileges;
           client.user.login(cb, partnerId, userId, password, expiry, privileges);
           return dfd.promise();
       }

       $.when(generateSessionString()).then(
               function(session)
               {
                   alert(session);
               }
       )

答案 1 :(得分:0)

@Itay Kinnrot的答案是对的。实际上,jQuery的on / trigger是解决它的另一种方法,但$ .Deferred更好。

如果您想了解更多信息,可以尝试了解Pub / Sub Pattern。 建议使用本文:

http://www.elijahmanor.com/2013/03/angry-birds-of-javascript-blue-bird.html