반응형
getDocuments -> addSnapshotListner로만 바꿔주면
실시간으로 업데이트 할 수 있다.
func loadMessages() { // firestore 시작하기 -> 데이터 읽기
db.collection(K.FStore.collectionName).addSnapshotListener { (querySnapshot, error) in
self.messages = [] // 비우고 넣고 비우고 넣고
if let e = error {
print("There was an issue retrieving data from Firestore. \(e)")
} else {
if let snapshotDocuments = querySnapshot?.documents {
for doc in snapshotDocuments { // 여기까지는 firebase데이터 읽기와 동일
let data = doc.data()
if let messageSender = data[K.FStore.senderField] as? String, let messageBody = data[K.FStore.bodyField] as? String {
let newMessage = Message(sender: messageSender, body: messageBody)
self.messages.append(newMessage)
DispatchQueue.main.async { // 인터페이스를 조작하려고 할 때마다(tableView를 업데이트하려고 하고 클로저 내부에 있는 경우 main queue에 홀드 시키는 습관 가지자
self.tableView.reloadData() // tableview를 탭하고 데이터 소스를 트리거할 수 있다는 것
}
}
}
}
}
}
}
반응형
'iOS > Swift 어플 따라하기' 카테고리의 다른 글
[Swift] reusablecell 회색 배경 없애기 (0) | 2022.09.07 |
---|---|
[Swift] Firestore에서 읽은 데이터를 시간 순으로 정렬 (0) | 2022.09.06 |
[Swift] FireStore에 저장한 데이터 불러오기(데이터 읽기) (0) | 2022.09.06 |
[Swift] FireStore에 데이터 저장하기 (0) | 2022.09.06 |
[Swift] Xib파일을 사용하여 TableView에서 셀 사용자 지정 (0) | 2022.09.06 |