如何在公共js模块中从web服务返回数据

How to return data from web service in common js module

本文关键字:web 服务 返回 数据 模块 js      更新时间:2023-09-26

我正在使用钛合金编写一个移动应用程序。我不知道如何编写一个返回对象的模块。我编写的版本返回"undefined"
如有任何帮助,我们将不胜感激!

这就是我在index.js 中使用模块的方式

    var ResArgs = require("WebData").GetItemDetails(args.barcode, args.type);
    Ti.API.info("Received data from WebGetData: " + ResArgs);

这是实际的WebData.js模块

exports.GetItemDetails = function(code, type) {
    var url = "http://url/" + code + "/" + type;
    var arg = null || {};
    var client = Ti.Network.createHTTPClient({
        // function called when the response data is available
        onload : function(e) {
            Ti.API.info("Received text from service: " + this.responseText);
            return this.responseText;
        },
        // function called when an error occurs, including a timeout
        onerror : function(e) {
            Ti.API.debug(e.error);
            alert('error: ' + e.error);
        },
        timeout : 5000 // in milliseconds
    });
    client.open("GET", url);
    // Send the request.
    client.send();
};

使用回调

exports.GetItemDetails = function(code, type, _callback) {
  var url = "http://url/" + code + "/" + type;
  var arg = null || {};
  var client = Ti.Network.createHTTPClient({
    // function called when the response data is available
    onload : function(e) {
        Ti.API.info("Received text from service: " + this.responseText);
        _callback && _callback({success : true, data : this.responseText});
    },
    // function called when an error occurs, including a timeout
    onerror : function(e) {
        Ti.API.debug(e.error);
        alert('error: ' + e.error);
        _callback && _callback({success : false, error:e.error});
    },
    timeout : 5000 // in milliseconds
  });
  client.open("GET", url);
  // Send the request.
  client.send();
};

然后你会调用类似的代码

var ResArgs = require("WebData");
ResArgs.GetItemDetails(args.barcode, args.type, function(_response){
  if ( _response.success ) {
     Ti.API.info("Received data from WebGetData: " + _response.data);
  } else {
     Ti.API.error("ERROR from WebGetData: " + _response.error);
  }
});

查看您的代码GetItemDetails没有return语句,因此正确地返回undefined。由于内部使用的API确实使用回调,因此代码不能以这种明确的方式编写,相反,您的GetItemDetails方法可能需要回调作为您在onload或/和onerror中调用的参数。

我希望这能解释问题。