Swift 4 - Центр уведомлений addObserver
Я сбой и получение ошибки unrecognized selector
каждый раз, когда прибывает Notification
, и приложение пытается выполнить связанный с ним метод.
Здесь мой код - который находится в viewDidLoad
:
let notificationCenter = NotificationCenter.default
notificationCenter.addObserver(self, selector: Selector(("sayHello")), name:NSNotification.Name(rawValue: "dataDownloadCompleted"), object: nil)
Метод sayHello()
довольно прост - выглядит так:
func sayHello() {
print("Hello")
}
Я проверил, что Notification
отправлен успешно и что он прибывает успешно - так что это не проблема. Сбой происходит, когда приложение выглядит так, чтобы приступить к приходу Notification
, выполнив метод sayHello()
. Он продолжает давать мне ошибку unrecognized selector
.
Любые идеи, что я делаю неправильно? (Кстати, это отлично работало с Swift 3 и Xcode 8, но теперь с Swift 4 и Xcode 9 синтаксис изменился [Xcode провела меня через необходимые исправления/обновления кода] - но аварийные ситуации продолжают происходить.)
Ответы
Ответ 1
Вы можете улучшить свой код с помощью следующих шагов:
extension Notification.Name {
static let dataDownloadCompleted = Notification.Name(
rawValue: "dataDownloadCompleted")
}
И используйте его следующим образом:
let notificationCenter = NotificationCenter.default
notificationCenter.addObserver(self,
selector: #selector(YourClass.sayHello),
name: .dataDownloadCompleted,
object: nil)
Но, как уже указывалось, проблема решается путем изменения на #selector
Ответ 2
Data Receiving - Add observer:
override func viewDidLoad() {
super.viewDidLoad()
NotificationCenter.default.addObserver(self, selector: #selector(yourfunction(notfication:)), name: .postNotifi, object: nil)
}
@objc func yourfunction(notfication: NSNotification) {
print("xxx")
}
Sending Data - Post Notification:
override func viewWillDisappear(_ animated: Bool) {
super.viewWillDisappear(animated)
NotificationCenter.default.removeObserver(self, name: .postNotifi, object: nil)
}
extension Notification.Name {
static let postNotifi = Notification.Name("postNotifi")
}
Ответ 3
Swift 4.0 & Xcode 9. 0+:
Отправить (Post) уведомление:
NotificationCenter.default.post(name: Notification.Name("NotificationIdentifier"), object: nil)
ИЛИ
NotificationCenter.default.post(name: Notification.Name("NotificationIdentifier"), object: nil, userInfo: ["Renish":"Dadhaniya"])
Получить (получить) уведомление:
NotificationCenter.default.addObserver(self, selector: #selector(self.methodOfReceivedNotification(notification:)), name: Notification.Name("NotificationIdentifier"), object: nil)
Обработчик метода-функции для полученного уведомления:
@objc func methodOfReceivedNotification(notification: Notification) {}
Swift 3.0 & Xcode 8. 0+:
Отправить (Post) уведомление:
NotificationCenter.default.post(name: Notification.Name("NotificationIdentifier"), object: nil)
Получить (получить) уведомление:
NotificationCenter.default.addObserver(self, selector: #selector(YourClassName.methodOfReceivedNotification(notification:)), name: Notification.Name("NotificationIdentifier"), object: nil)
Обработчик метода для полученного уведомления:
func methodOfReceivedNotification(notification: Notification) {
// Take Action on Notification
}
Удалить уведомление:
deinit {
NotificationCenter.default.removeObserver(self, name: Notification.Name("NotificationIdentifier"), object: nil)
}
Swift 2.3 & Xcode 7:
Отправить (Post) уведомление
NSNotificationCenter.defaultCenter().postNotificationName("NotificationIdentifier", object: nil)
Получать (получать) уведомления
NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(YourClassName.methodOfReceivedNotification(_:)), name:"NotificationIdentifier", object: nil)
Обработчик метода для полученного уведомления
func methodOfReceivedNotification(notification: NSNotification){
// Take Action on Notification
}
Ref:https://medium.com/@javedmultani16/notification-in-swift-4-8b0db631f49d