Работа с задержкой из-за асинхронной связи в AlamoFire - PullRequest
0 голосов
/ 21 июня 2019

Я понимаю, что связь AlamoFire и URL с облачной базой данных является асинхронной. Мой вопрос заключается в том, как большинство людей справляются с задержкой второй пары. Мое приложение сохраняет адрес электронной почты пользователей и значение bool true, если они вошли в систему. Если true, оно переходит ко второму контроллеру представления с подробной информацией. Из-за задержки нет информации. Я поставил 2-секундную задержку, но на переходах из вида один в два она выглядит неопрятно. Прикрепленный код. Я также думаю, экран ожидания, но не уверен. Любая помощь будет отличной. Спасибо.

var defaultValue:UserDefaults!

override func viewDidLoad() {
    super.viewDidLoad()

    defaultValue = UserDefaults.standard
    if let emailUD = defaultValue.object(forKey: "loginEmail") as? String{
        textEmail.text = emailUD
        print("Stored email -", emailUD)
    }
    if let loggedin = defaultValue.object(forKey: "isLoggedIn") as? Bool{
        if loggedin != true{
                let parameters1: Parameters=[
                    "email":"perry.aten@mymail.com",
                    "password":passwordIn
                ]
                Alamofire.request(URL_USER_LOGIN, method: .get, parameters: parameters1).responseJSON
                    { response1 in
                        if response1.result.value != nil{
                            let guardianJSON = JSON(response1.result.value!)
                            let guardian:String = guardianJSON[0]["guardian"].string!
                            print(guardian)
                            print(guardianJSON)

                            let league:String = guardianJSON[0]["league"].string!
                            let parameters2: Parameters=[
                                "league":league
                            ]
                            //Getting League name
                            Alamofire.request(URL_LEAGUE, method: .get, parameters: parameters2).responseJSON
                                { response2 in
                                    if response2.result.value != nil {
                                        let leagueJSON = JSON(response2.result.value!)
                                        leagueName=leagueJSON[0]["name"].string!
                                        print(leagueJSON)
                                    }
                            }
                        }
                }
            DispatchQueue.main.asyncAfter(deadline: .now() + 2.0){
                let loggedInVC = self.storyboard?.instantiateViewController(withIdentifier: "LoggedInID") as! LoggedINViewController
                self.present(loggedInVC, animated: false, completion: nil)
                print("They are logged in viewDidLoad")
            }
        }
    }
}

1 Ответ

0 голосов
/ 21 июня 2019

Это

DispatchQueue.main.asyncAfter(deadline: .now() + 2.0){
  let loggedInVC = self.storyboard?.instantiateViewController(withIdentifier: "LoggedInID") as! LoggedINViewController
  self.present(loggedInVC, animated: false, completion: nil)
  print("They are logged in viewDidLoad")
}

- не точный путь, поскольку может пройти 2 секунды, а запрос все еще не будет возвращен или возвращен раньше, и это будет задержкой в ​​вашем приложении, котороене очень хорошая практика, вам нужно создать функцию и вызывать ее из функции обратного вызова, например

Alamofire.request(URL_LEAGUE, method: .get, parameters: parameters2).responseJSON   { response2 in

  if response2.result.value != nil {
    let leagueJSON = JSON(response2.result.value!)
    leagueName=leagueJSON[0]["name"].string!
    print(leagueJSON)

     // call here
    self.next()
  }
}


func next() {
   let loggedInVC = self.storyboard?.instantiateViewController(withIdentifier: "LoggedInID") as! LoggedINViewController
   self.present(loggedInVC, animated: false, completion: nil)
   print("They are logged in viewDidLoad")
}   
...