現在個人アプリを制作しており、育児状況を記録するため、その一画面をUITableViewで実装しております。具体的には、画面上部に表示された日付ごとにUITableViewCellに表示された内容をRealmを用いて記録、セルに表示したいです。
日付を切り替えるとセルの内容も書き換えられるような形にしたいです。
参考にした記事URL: https://qiita.com/yanashi222/items/121b549852bedf391377- Realm公式サイトを参考
表示された日付ごとにセルの内容を表示したい。具体的には、表示日付が変更されたら、それに伴ってセルの内容を書き換られるようにしたい。
発生したエラーや意図しない挙動の説明
前日ボタンやcellForRowAtに以下のコードを記載して試して見ましたが、日付が変更されても、セルの内容は変わりませんでした。
swift
1 2こちらです! 3//セル数宣言 4 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 5 6 let realm = try! Realm() 7 return todoItems.count 8 } 9 10//セル表示 11 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 12 let cell = tableView.dequeueReusableCell(withIdentifier: "RecordCell", for: indexPath) as! TableViewCell 13 14 let realm = try! Realm() 15 let object = todoItems[indexPath.row] 16 cell.bindData(text: object.title, label: object.nowTime, image: object.buttonImage!) 17 let record = Record() 18 19 var result = realm.objects(Record.self) 20 21 result = result.filter("date = '(labelToday.title)'") 22 23 for rd in result { 24 25 if rd.date == labelToday.title { 26 27 record.title = rd.title 28 29 record.nowTime = rd.nowTime 30 31 record.buttonImage = rd.buttonImage 32 33 } 34 } 35 return cell 36 } 37 38 39 func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool { 40 return true 41 } 42 43 44 func tableView(_ tableView: UITableView,commit editingStyle: UITableViewCell.EditingStyle,forRowAt indexPath: IndexPath) { 45 if editingStyle == .delete{ 46 if let object = todoItems?[indexPath.row] { 47 tableView.reloadData() 48 let realm = try! Realm() 49 try! realm.write{ 50 realm.delete(object) 51 } 52 tableView.deleteRows(at: [indexPath], with: UITableView.RowAnimation.automatic) 53 } 54 } 55 } 56 57 func scrollViewDidScroll(_ scrollView: UIScrollView) { 58 return 59 } 60 61 62 func deleteTodo(Index: Int){ 63 let realm = try! Realm() 64 try! realm.write{ 65 realm.delete(todoItems[Index]) 66 } 67 68 } 69
- デバッグ内容と自身の考察
e.g.- Realmのfilterで、表示されている日付と同じだったら、それに対応したセルの内容を取り出せばいいのではと考え上記の通り実行しました。
表示している日付date(string)にprimary keyを指定して実装しましたがうまくいきません。
日付に紐づいたUITableViewCellを表示をさせる場合、‘tableView(_: cellForRowAt)’または、前日ボタンに記載するという実装方針は合っているか、
どちらもも違っているのであれば、どのような実装方針がよいのかアドバイス頂きたいです。
UITableViewのreloadは行っていますか?またコードは変に省略するより、ある程度載せたほうが問題点が見やすく助かります。
コード関係分載せました!
reloadしてませんでした????
基本的な流れとしては、ViewController表示する際にrealmからデータを読み込み、配列などの変数に格納します。その後は、その変数を参照して動作するようにすれば良いです。データの変更があった場合、その変数を修正し、ViewControllerが終了するときに書き出すようにします。
reload実施してました!
基本的な流れでは実装できているのですが、画面上部の日付とセルに表示されている内容が紐づいていないために、日付を変更してもセルの内容が変わらないのです????
こういった場合モデル定義や、検索条件の指定などでアドバイスありますでしょうか?
モデル定義は以下のようにしておりました!
```
import Foundation
import RealmSwift
class Record: Object{
static let realm = try! Realm()
@objc dynamic var title = ""
@objc dynamic var nowTime = ""
@objc private var _buttonImage: UIImage? = nil
@objc dynamic var buttonImage: UIImage? {
set{
self._buttonImage = newValue
if let value = newValue {
self.imageData = value.pngData()
}
}
get{
if let image = self._buttonImage {
return image
}
if let data = self.imageData {
self._buttonImage = UIImage(data: data)
return self._buttonImage
}
return nil
}
}
@objc dynamic private var imageData: Data? = nil
override static func ignoredProperties() -> [String] {
return ["buttonImage", "_buttonImage"]
}
func save() {
try! Record.realm.write{
Record.realm.add(self)
}
}
}
```
filterした結果をcellに設定していないように見えます。
あと出来ならばコードの正しくネストしましょう。
しっかりネストされていたほうが見やすく迅速に解決できます。
結果をセルに設定したところ、セルが表示されなくなってしまいました!
ネストについては、理解不足のため、調べて改善します。
言われたことをただ試すのではなく、改善する努力を行ってください。表示されなくなってしまったのならなぜそうなったのか、設定はされているけど空文字が設定されているのか、空文字ではないけどAutoLayoutが悪さをしているのか、高さ等を計算しているなら計算が間違っているのか等です。ただ表示されないと言われても原因が不明なため回答のしようがありません。

あなたの回答
tips
プレビュー