10

我有一个我想重用的函数,并让它接受 Decocable 结构的参数。例如,这是我当前代码的简化(假设“MyDecodableStruct”是应用程序其他地方声明的可解码结构):

 static func getResults(url: String, parameters: Parameters) {
    // On success REST response
     if response.result.isSuccess {
        struct Results: Decodable {
          let items: [MyDecodableStruct]
         }

      if let jsonResults = try? JSONDecoder().decode(Results.self, from: response.data!) {
        //success
    }
}

而不是说“MyDecodableStruct”,我希望它是我作为参数传入的任何可解码结构。像这样的东西:

 static func getResults(url: String, parameters: Parameters, myStruct: Decodable) {
    // On success REST response
     if response.result.isSuccess {
        struct Results: Decodable {
          let items: [myStruct]
         }

      if let jsonResults = try? JSONDecoder().decode(Results.self, from: response.data!) {
        //success
    }
}

我会这样称呼它

 getResults(url: "url", parameters: nil, myStruct: MyDecodableStruct)

我无法弄清楚如何让它工作的语法。我得到的错误是

Type 'Results' does not conform to protocol 'Decodable'
Expected element type

有关处理此问题的最佳方法的任何想法?

4

1 回答 1

18

当您想将类型作为参数传递时,您需要将参数的类型声明为metatype。在您的情况下,它是一个需要符合的泛型类型Decodable

所以你可能需要写这样的东西:

struct Results<Element: Decodable>: Decodable {
    let items: [Element]
}
static func getResults<Element: Decodable>(url: String, parameters: Parameters?, myStruct: Element.Type) {
    //...
        // On success REST response
        if response.result.isSuccess {

            do {
                let jsonResults = try JSONDecoder().decode(Results<Element>.self, from: response.data!)
                //success
                print(jsonResults)
            } catch {
                //Better not dispose errors silently
                print(error)
            }
        }
    //...
}

Swift 说类型不能嵌套在泛型上下文中,所以我将它移到外部非泛型上下文中。

称它为:

getResults(url: "url", parameters: nil, myStruct: MyDecodableStruct.self)
于 2017-10-26T21:38:03.023 回答