UIAlertController,其视图不在窗口层次结构中

时间:2015-10-02 07:08:52

标签: swift swift2 uialertcontroller

我试图用Swift和Parse创建一个应用程序。我正在使用Xcode 7和Swift 2。 我想在用户登录失败时显示警告消息,这是我的功能:

func logInViewController(logInController: PFLogInViewController, didFailToLogInWithError error: NSError?){
    let alertLoginFailed = UIAlertController(title: "Login Failed", message: "Your username or password is invalid!", preferredStyle: UIAlertControllerStyle.Alert)
    alertLoginFailed.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.Default, handler: nil))
    self.presentViewController(alertLoginFailed, animated: true, completion: nil)
    print("Login failed.........!")
}

但是我在模拟器中运行时遇到了这个错误:

2015-10-02 11:32:39.988 RedString[2089:886501] Warning: Attempt to present <UIAlertController: 0x7a934400> on <MyProject.ViewController: 0x7b985150> whose view is not in the window hierarchy!
Login failed.........!

我已经开始搜索它,但我没有找到明确的解决方案。

这是我的全班:

import UIKit
import Parse
import ParseUI
class ViewController: UIViewController, PFLogInViewControllerDelegate, PFSignUpViewControllerDelegate {

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

    override func viewDidAppear(animated: Bool) {
        self.setupLoginView()
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func logInViewController(logInController: PFLogInViewController, didLogInUser user: PFUser){
        self.dismissViewControllerAnimated(true, completion: nil)
    }

    func logInViewController(logInController: PFLogInViewController, didFailToLogInWithError error: NSError?){
        let alertLoginFailed = UIAlertController(title: "Login Failed", message: "Your username or password is invalid!", preferredStyle: UIAlertControllerStyle.Alert)
        alertLoginFailed.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.Default, handler: nil))
        self.presentViewController(alertLoginFailed, animated: true, completion: nil)
        print("Login failed.........!")
    }

    func signUpViewController(signUpController: PFSignUpViewController, didSignUpUser user: PFUser){
        self.dismissViewControllerAnimated(true, completion: nil)
    }

    func signUpViewController(signUpController: PFSignUpViewController, didFailToSignUpWithError error: NSError?){
        print("Sign up failed.........!")
    }

    func setupLoginView(){
        if(PFUser.currentUser() == nil){
            let loginViewController = PFLogInViewController()
            loginViewController.delegate = self
            let signUpViewController = PFSignUpViewController()
            signUpViewController.delegate = self
            loginViewController.logInView!.logo = UIImageView(image: UIImage(named:"logo.png"))

            loginViewController.signUpController = signUpViewController
            self.presentViewController(loginViewController, animated: true, completion: nil)
        }else{
            print("login as: " + PFUser.currentUser()!.username!)
            //prepare new view here
        }

    }
}

3 个答案:

答案 0 :(得分:0)

您必须在登录视图控制器上调用presentViewController:animated:completion

以下是您班级的简化版本,以向您展示我的意思:

class ViewController: UIViewController {
    weak var loginViewController: UIViewController?

    func setupLoginViewController() {
        let loginVC = PFLogInViewController()
        // setup loginVC
        loginViewController = loginVC // store the reference
    }

    func loginDidFail() {
        let alertVC = UIAlertController(...)
        // setup alertVC
        loginViewController?.presentViewController(...) // present the alert from the login view controller
    }
}

答案 1 :(得分:0)

何时

func logInViewController(logInController: PFLogInViewController, didFailToLogInWithError error: NSError?){
        let alertLoginFailed = UIAlertController(title: "Login Failed", message: "Your username or password is invalid!", preferredStyle: UIAlertControllerStyle.Alert)
        alertLoginFailed.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.Default, handler: nil))
        self.presentViewController(alertLoginFailed, animated: true, completion: nil)
        print("Login failed.........!")
    }
调用

,您的视图控制器不在屏幕上。因此你可以

  • 关闭logInViewController,然后显示警告并传递 setUpLogInView作为处理程序。

  • 或在上述功能中,试试logInController.presentViewController 而不是self.presentViewController

答案 2 :(得分:0)

我在Objective-C中遇到了同样的问题,当父窗口尚未绘制到屏幕时会发生这种问题。我通过从viewDidAppear而不是viewDidLoad中调用代码来解决问题。见UIAlert error, whose view is not in the window hierarchy