2016-11-22 3 views
1

Я новичок в разработке Swift и iOS. Я пытаюсь создать проверку для подключения к Интернету, которая позволяет пользователю повторить попытку (перезагрузить текущее представление). Функция checkInternetConnection() приведена ниже во время viewWillAppear() в моем классе BaseUIViewController.Перейдите к UIViewController из UIAlertView в Swift 2.3

Reachability.isConnectedToNetwork() проверка связи хорошо. Но до сих пор мне не удалось выяснить способ перезагрузки текущего представления после того, как пользователь нажмет кнопку «Повторить» в предупреждении. на самом деле, мне не удалось выяснить способ перезагрузки текущего представления в любом сценарии.

Одна вещь, которую я знаю, что я делаю неправильно в следующей попытке (так как ошибка компиляции говорит мне, так), что я пропусканием UIViewController объект в качестве параметра вместо string на этой линии: self.performSegueWithIdentifier(activeViewController, sender:self), но Я подозреваю, что это не моя единственная ошибка.

func checkInternetConnection() { 
    if (Reachability.isConnectedToNetwork()) { 
    print("Internet connection OK") 
} else { 
    print("Internet connection FAILED") 
    let alert = UIAlertController(title: NSLocalizedString("Error!", comment: "Connect: error"), message: NSLocalizedString("Could not connect", comment: "Connect: error message"), preferredStyle: UIAlertControllerStyle.Alert) 
    alert.addAction(UIAlertAction(title: NSLocalizedString("Retry", comment: "Connect: retry"), style: .Default, handler: { action in 
     print("Connection: Retrying") 
     let navigationController = UIApplication.sharedApplication().windows[0].rootViewController as! UINavigationController 
     let activeViewController: UIViewController = navigationController.visibleViewController! 
     self.performSegueWithIdentifier(activeViewController, sender:self) 
    })) 
    self.presentViewController(alert, animated: true, completion: nil) 
    } 
} 
+0

его '' performSegueWithIdentifier' не performSegueWithViewController', так что вы должны использовать идентификатор (String) в Segue (вы можете установить на раскадровке), или вы можете просто используйте 'presentViewController', чтобы представить его. – RJE

+0

Спасибо, но я не могу ввести строковое значение здесь, так как я не знаю, на какой взгляд пользователь получил предупреждение (и, следовательно, я не знаю, какое представление представить пользователю, когда они нажимают «Повторить»). Он должен быть динамичным. –

+0

Затем создайте динамическую строку на основе следующих vc, которые у вас есть, и поставьте там ...? – Tj3n

ответ

0

BaseUIViewController может выполнять приложения ширины проверки для подключения, так что все ваши ViewControllers будут унаследованной от BaseUIViewController.

И каждый ViewController будет иметь другое поведение после проверки соединения.

Одна вещь, которую вы можете сделать, - в вашем BaseUIViewController вы можете определить блок, который выполняет действия после проверки подключения.

Вот пример:

class BaseViewUIController: UIViewController { 

    var connectivityBlock: (() -> Void)? 

    override func viewDidAppear(_ animated: Bool) { 
     super.viewDidAppear(animated) 
     checkInternetConnection() 
    } 


    func checkInternetConnection() { 
     if Reachability.isConnectedToNetwork() { 
      print("Internet connection OK") 
     } else { 
      if let b = connectivityBlock { 
       b() 
      } 
     } 
    } 
} 

И в ваших унаследованных ViewControllers:

class MyViewController: BaseUIViewController { 
    override func viewDidLoad() { 
     super.viewDidLoad() 
     connectivityBlock = { 
      print("Do View Refresh Here.") 
     } 
    } 
} 

Затем После проверки в BaseUIViewController, код в connectivityBlock будет выполнен так, что каждый VC может справиться с ней иначе.

Вы также можете определить функцию в BaseUIViewController, и каждый подкласс будет переопределять эту функцию после того, как проверка соединения не удалась, вызовите функцию.

окна
+0

Спасибо за предложение. Я не уверен, что мне нужно различное поведение для каждого ViewController, но я полагаю, это не повредит. Тем не менее, я получаю ошибку компиляции _Cannot преобразовать значение типа «testingViewController.Type» в ожидаемый тип аргумента «UIViewController» в определении 'connectivityBlock()' в моем 'testViewController: BaseUIViewController'. Определение содержит одну строку: 'self.presentViewController (testingViewController, animated: false, completion: nil)' и написано непосредственно под 'super.viewDidLoad()', как в вашем примере –

+0

Итак, ваше предложение, вероятно, звучит, но моя оригинальная проблема сохраняется. Мне нужно перезагрузить текущий ViewController. Это должно быть сделано там, где вы написали 'print (« Do View Refresh Here. »)' –

+0

Вы правы, вы можете просто перезагрузить текущий VC в блоке, как если бы вы перезагружали/обновляли ваш просмотр в обычном режиме. – Zeyu

0

Try навигация с помощью приложения

let destinationVC = UIApplication.shared.delegate?.window 
destinationVC .present(activeViewController, animated: true, completion: nil) 
+0

Несколько проблем ... 'let destinationVC = UIApplication.shared.delegate? .window' дает ошибку компиляции _« Тип «UIApplication» не имеет общего доступа для участников »_... Может ли это быть то, что вы имели в виду:' let destinationVC = UIApplication.sharedApplication(). делегируют? .window'? Но тогда «destinationVC .present (activeViewController, animated: true, completion: noil)» дает ошибку компиляции _ «Значение типа« UIWindows ?? » не имеет участника 'present' '_ –

+0

, какую быструю версию вы использовали? – KKRocks

+0

Просто указал его в заголовке. Swift 2.3 –

Смежные вопросы