如何使用来自两个单独的Alamofire请求的数据初始化对象?

时间:2015-03-18 04:38:30

标签: ios swift foursquare alamofire swifty-json

我正试图向Foursquare的Photos From a Venue发送GET请求 Foursquare的Explore同时出现。现在(如果我错了,请纠正我)我有两种方法通过Alamofire发出请求,并使用SwiftyJSON将响应转换为JSON对象。

我可以使用下面的makeRequest()成功更新UITableViewCell的标签以反映数据,但无法更新每个相应单元格的背景照片的UIImage。

我的问题是A)获得可用的照片URL,以及B)在提供来自两个单独请求的数据时初始化“pin”。为了初始化引脚,我需要设置所有值。我从一个请求中获取90%的值,从另一个请求中获取10%(我需要获取的照片URL)。如何使用来自两个单独请求的数据初始化“pin”?

makeImageRequest

    func makeImageRequest() {

    let venueID = "43695300f964a5208c291fe3"
    let firstURL = "https://api.foursquare.com/v2/venues/\(venueID)/photos"

    Alamofire.request(.GET, firstURL, parameters: [
        "client_id" : foursquareClientID,
        "client_secret" : foursquareClientSecret,
        "v" : "20140806",
        "m" : "foursquare",
        "limit" : "10"
        ])
        .responseJSON { (request, response, data, error) in
            println(request)
            println(response)
            println(error)

            let jsonObj = JSON(data!)
            self.pins = []
            for obj in jsonObj["response"]["photos"]["items"].arrayValue {
                let photoURL = obj["prefix"]["suffix"].stringValue
                println("the photo url is\(photoURL)")
                let pin = Pin(title: obj["venue"]["name"].stringValue, openUntil: obj["venue"]["hours"]["status"].stringValue, address: obj["venue"]["location"]["address"].stringValue, ratingSignals: obj["venue"]["ratingSignals"].stringValue, ratingImage: UIImage(named:"Score8-5")!, venueImage: UIImage(named: "FloraGrubTestImage.jpg")!)
                self.pins.append(pin)
            }
            self.tableView.reloadData()

    }
}

makeRequest

    func makeRequest(searchString: String) {

    let secondURL = "https://api.foursquare.com/v2/venues/explore"

    Alamofire.request(.GET, secondURL, parameters: [
        "client_id" : foursquareClientID,
        "client_secret" : foursquareClientSecret,
        "ll" : "37.71987,-122.470089",
        "query" : searchString,
        "radius" : "1000",
        "limit" : "10",
        "v" : "20140806",
        "m" : "foursquare"
        ])
        .responseJSON { (request, response, data, error) in
            println(request)
            println(response)
            println(error)

            let jsonObj = JSON(data!)
            self.pins = []
            println(jsonObj)
            for obj in jsonObj["response"]["groups"][0]["items"].arrayValue {
                let pin = Pin(title: obj["venue"]["name"].stringValue, openUntil: obj["venue"]["hours"]["status"].stringValue, address: obj["venue"]["location"]["address"].stringValue, ratingSignals: obj["venue"]["ratingSignals"].stringValue, ratingImage: UIImage(named:"Score8-5")!, venueImage: UIImage(named: "FloraGrubTestImage.jpg")!)
                self.pins.append(pin)
            }
            self.tableView.reloadData()
    }
}

我的UITableViewCell类中有一个单独的bindData()方法。这有意义吗?任何人都可以帮助我吗?

更新:我工作的工程师建议我在同一方法makeRequest中发出另一个请求,而不是将其分解为两个单独的方法。我还在线阅读了一个教程,建议使用某种响应路由器。关于如何将此代码重构为一种方法的任何建议?

更新#2:我已经重新命名了这个问题,因为我意识到原来的问题不是我真正的问题

1 个答案:

答案 0 :(得分:1)

最简单的方法是串行执行这些请求。首先检索所有引脚,然后检索所有照片。这基本上是另一位工程师的建议。

如果您并行触发这些请求,则需要额外的工作来合并响应,因为您不知道哪个请求将首先返回。

现在要合并引脚,您需要一种方法来唯一标识每个引脚。如果他们有一些ID,你可以使用它。否则,您必须依赖排序顺序和索引。假设每个请求以相同的顺序返回相同的引脚。

第一个请求返回后,您有一个引脚数组。然后在第二个请求回调中,您可以从该数组中检索匹配的引脚,并使用新数据进行更新。