[swift] NotificationCenter 간단 예제
첨부 '1' |
|
---|
How To Post Notifications
Now that we’re observing for a notification, let’s post it! Posting a notification is simple:
NotificationCenter.default.post(name: .didReceiveData, object: nil)
The function post(name:object:userInfo:)
has 3 parameters:
- The first parameter is
name
, the notification name, of typeNotification.Name
. It’s exactly the same as the notification you’re observing, and it’s smart to use that extension here too. - The second parameter is
object
, the sender of the notification. You can leave it empty withnil
or use any object. It’s purpose is the same as theobject
parameter ofaddObserver(...)
, so you can use it to filter the sender of a notification. - The third parameter is
userInfo
, and you can use it to send extra data with the notification. The parameter is not required, so you can leave it out if you don’t need it.
Let’s say you want to display some data in a table view. The data comes from a JSON webservice, and contains the game scores of Bob, Alice and Arthur.
You register for the .didReceiveData
notification in the table view controller, like this:
NotificationCenter.default.addObserver(self, selector: #selector(onDidReceiveData(_:)), name: .didReceiveData, object: API.shared)
And the onDidReceiveData(_:)
function looks like this:
@objc func onDidReceiveData(_ notification: Notification)
{
if let data = notification.userInfo as? [String: Int] {
for (name, score) in data {
print("\(name) scored \(score) points!")
}
}
}
In the example above, this happens:
- First, you’re using conditional binding to downcast the type of
userInfo
to[String: Int]
with the type cast operatoras?
. Because the type ofuserInfo
is[AnyHashable: Any]?
– basically any dictionary – you can downcast its type to the dictionary type you’re expecting. That’s string keys and integer values in the example above. If the cast succeeds, thendata
contains the value ofuserInfo
as type[String: Int]
. - Then, using a for in loop, the items in the
data
dictionary are iterated. We’re using a tuple(name, score)
to decompose the key and value of the dictionary items. - Finally, inside the loop, we’re printing out the names and scores of Bob, Alice and Arthur.
When we want to post the notification that contains the data, we do this:
let scores = ["Bob": 5, "Alice": 3, "Arthur": 42]
NotificationCenter.default.post(name: .didReceiveData, object: self, userInfo: scores)
See how the scores
dictionary is provided as the argument for userInfo
? We’re basically sending those score data alongside the notification. They’ll get picked up in onDidReceiveData(_:)
and printed out.
Another thing stands out in the example above: the usage of object
. When registering the observer, you’re specifying the sender you want to receive notifications from. Like this:
addObserver(···, selector: ···, name: ···, object: API.shared)
Then, when posting the notification we specify the object
parameter too. Like this:
.post(name: ···, object: self, userInfo: ···)
You already know that self
refers to the current instance of the class we’re in. So when API.shared
references the same object as self
, the notification is picked up by the observer.
Here’s what that class could look like:
class API
{
static let shared = API()
func getData() {
NotificationCenter.default.post(name: .didReceiveData, object: self, userInfo: ···)
}
}
And that’s how we post notifications! Let’s continue with some use cases…
[출처] https://learnappmaking.com/notification-center-how-to-swift/
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
781 | Develop | [ios] iOS 8 개발자가 우선 알아야 할 3가지 | hooni | 2014.10.02 | 982 |
780 | Develop | [android] AlertDialog 메시지 창 띄우기 | hooni | 2015.07.09 | 983 |
779 | Develop | [kotlin] 코틀린 안드로이드 앱 버전/빌드 정보 | hooni | 2020.12.15 | 986 |
778 | Develop | [ios] APNS에 사용할 인증서 만들기 (KeyChain에 있는 인증서 Export) | hooni | 2015.01.03 | 989 |
777 | Develop | [js] 좋은 강연자료 & UI 자료 | hooni | 2014.10.06 | 991 |
776 | Develop | [ios] ViewController Push할 때 애니메이션 효과 | hooni | 2015.10.23 | 995 |
775 | Develop | [c] RSA 암호화 구현(gmp 라이브러리 활용) | hooni | 2016.10.03 | 1015 |
774 | Develop | XE Core 1.8.18 본문 작성시 태그(html) 사라지는 버그 | hooni | 2016.04.21 | 1023 |
773 | Develop | [js] AngularJS 란? | hooni | 2015.11.26 | 1033 |
772 | Develop | [ios] 로컬에 있는 JS 파일 웹뷰에서 동적으로 실행하기 | hooni | 2015.02.10 | 1077 |
771 | Develop | [ios] 오브젝티브C→스위프트, 코드 변환 손쉽게 | hooni | 2015.08.07 | 1080 |
770 | Develop | [android] 딜레이를 구현하기 위한 꼼수 | hooni | 2016.11.24 | 1081 |