斯威夫特的关闭

时间:2014-12-27 12:44:35

标签: swift closures alamofire

我刚开始在项目中使用Swift。在阅读Alamofire库的说明时,我发现了一些代码:

extension Request {
    class func XMLResponseSerializer() -> Serializer {
        return { (request, response, data) in
            if data == nil {
                return (nil, nil)
            }

            var XMLSerializationError: NSError?
            let XML = ONOXMLDocument.XMLDocumentWithData(data, &XMLSerializationError)

            return (XML, XMLSerializationError)
        }
    }

    func responseXMLDocument(completionHandler: (NSURLRequest, NSHTTPURLResponse?, OnoXMLDocument?, NSError?) -> Void) -> Self {
        return response(serializer: Request.XMLResponseSerializer(), completionHandler: { (request, response, XML, error) in
            completionHandler(request, response, XML, error)
        })
    }
}

在第二个函数responseXMLDocument中我想知道为什么我们必须重写闭包。如果函数的参数已经是一个闭包,为什么我们不能只写:

return response(serializer: Request.XMLResponseSerializer(), completionHandler:completionHandler)

我尝试了但它没有编译。

1 个答案:

答案 0 :(得分:0)

在我发布问题后,我突然想到了...... 问题是参数的类型不匹配。更具体地说,它是XML参数,应该是AnyObject?,是OnoXMLDocument?在内部处理程序中。