Запрос с Alamofire - PullRequest
       27

Запрос с Alamofire

0 голосов
/ 20 октября 2019

Я начинаю с swift и пытаюсь привести список автомобилей с alamofire, но он не приносит Код выполняется без ошибок, но не в списке. Я вижу пустое табличное представление

https://uploaddeimagens.com.br/imagens/simulator_screen_shot_-_iphone_8_-_2019-10-20_at_16-48-23-png

(извините ... редактирование с использованием кода записи)

Мои занятия

struct HotelData: Codable  {
    let results: [Results]
}

struct Results: Codable  {
    let smallDescription: String
    let price: Price
    let gallery: [ImageHotel]
    let name: String
    let address: Address

    var getRandonImage: ImageHotel {
        let index = Int(arc4random_uniform(UInt32(gallery.count)))
        return gallery[index]
    }
}

==============

Мой менеджер

class func getHotels(onComplete: @escaping (HotelData?) -> Void) {
        AF.request(path).responseJSON { (response) in
            guard let jsonData = response.data else { return }
            guard let hotelData = try? JSONDecoder().decode(HotelData.self, from: jsonData)
                else {
                    onComplete(nil)
                    return
            }
            onComplete(hotelData)
            return
        }
    }
}

==============

Ячейка

func prepareCell(with hotel: Results){
        lbName.text = hotel.name
        lbSmallDescription.text = hotel.smallDescription
        lbPrice.text = "R$ \(hotel.price.amount)"
        lbAdress.text = hotel.address.city
    }

==============

Класс TableView HotelTableViewController: UITableViewController {

            var hotels: [Results] = []
            let hotelManager = HotelManager()

            override func viewDidLoad() {
                super.viewDidLoad()
                loadHotels()
            }


            override func viewWillAppear(_ animated: Bool) {
                super.viewWillAppear(animated)

            }


            override func numberOfSections(in tableView: UITableView) -> Int {
                return 1
            }


            override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
                return hotels.count

            }


            override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
                let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! HotelTableViewCell
                let hotel = hotels[indexPath.row]
                cell.prepareCell(with: hotel)
                return cell
                }


            func loadHotels() {
                HotelManager.getHotels { (hotelData) in
                    if let hotelData = hotelData {
                        self.hotels += hotelData.results
                    }
                }
            }

        }

1 Ответ

0 голосов
/ 21 октября 2019

Ваша прямая проблема заключается в том, что вам нужно позвонить reloadData(), если вы хотите, чтобы ваш UITableView посмотрел на загруженные данные и загрузил соответствующие ячейки. Вы можете добавить обработчик завершения вашего сетевого вызова или didSet в свойстве hotels.

Кроме того, вы не должны использовать responseJSON для типов Decodable, это избыточно. Вместо этого вы должны использовать responseDecodable и передать тип, который вы хотите проанализировать: responseDecodable(of: HotelData.self) { response in ... }.

...