質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
TableView

TableView(UITableView)とは、リスト形式で表示するコントロールで、ほとんどのアプリに使用されています。画面を「行」に分けて管理し、一般的には各行をタップした際に詳細画面に移動します。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

1回答

254閲覧

テーブルビューのセルの削除後に、残りのセルが一段づつ上に詰まるようにしたいです

Atsuya-11

総合スコア12

TableView

TableView(UITableView)とは、リスト形式で表示するコントロールで、ほとんどのアプリに使用されています。画面を「行」に分けて管理し、一般的には各行をタップした際に詳細画面に移動します。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2020/01/18 11:38

前提・実現したいこと

tableViewにセルを表示しているのですが
セルをスワイプして削除すると、削除したセルより下のセルが一段づつ上に詰まるのではなく
一番下にあったセルが消したセルの段に入ってきてしまい、順番が変わってしまいます。
どのようにセルを消すコードをかけば一段づつ詰まるようになるでしょうか。。。

該当のソースコード

一番下にセルを消す処理があります。

import UIKit import RealmSwift class ViewController: UIViewController,UITableViewDataSource,UITextFieldDelegate,UITableViewDelegate { //箱を作っている var todoItems: Results<ItemBox>! @IBOutlet weak var table: UITableView! override func viewDidLoad() { super.viewDidLoad() table.dataSource = self let realm = try! Realm() //箱に実体を入れている todoItems = realm.objects(ItemBox.self) table.reloadData() table.delegate = self //空のセルの区切り線を消す処理 table.tableFooterView = UIView() //ナビバーのタイトルを大きくする(スクロール時は小さくなる) navigationController?.navigationBar.prefersLargeTitles = true } func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return 50 } override func viewWillAppear(_ animated: Bool) { super.viewWillAppear(animated) table.dataSource = self let realm = try! Realm() todoItems = realm.objects(ItemBox.self) table.reloadData() } func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return todoItems.count } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) let object = todoItems[indexPath.row] cell.textLabel?.text = "  "+object.title cell.textLabel?.font = UIFont(name: "Arial-BoldMT", size: 16) return cell } func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) { if editingStyle == .delete { deleteTodo(at:indexPath.row) table.reloadData() } } // var currentItem: String? = nil // var currentMemo = "" var todotoday: ItemBox? var receiveitemBox: ItemBox? func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { tableView.deselectRow(at: indexPath, animated: true) receiveitemBox = todoItems[indexPath.row] self.performSegue(withIdentifier: "tomemo", sender: nil) } @IBAction func nippou(_ sender: Any) { self.performSegue(withIdentifier: "autonippou", sender: nil) } override func prepare(for segue: UIStoryboardSegue, sender: Any?) { if segue.identifier == "tomemo" { let memoViewController:memoViewController = segue.destination as! memoViewController memoViewController.itemBox = receiveitemBox! } if segue.identifier == "autonippou" { let autonippouViewController:autonippouViewController = segue.destination as! autonippouViewController } } func deleteTodo(at index: Int) { let realm = try! Realm() try! realm.write { realm.delete(todoItems[index]) } } }

試したこと

よろしくお願いいたします。。。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2020/01/18 23:16

tableView(_:commit:forRowAt:)で table.reloadData()の代わりに table.deleteRows(at: [indexPath], with: .automatic)とした場合の結果がどうなるかおしえてくれませんか?
Atsuya-11

2020/01/19 07:20 編集

消した際は大丈夫なんですが セルをタップすると順番が入れ替わってしまいます。。。
guest

回答1

0

RealmSwiftを使ってるようですが、モデルクラスにprimaryKeyを設定しないとRealmが毎回同じ順序で取得してくれないようです。

ItemBoxクラスに以下のようにseq(idでもなんでもいいですが)を追加し、データ毎にユニークの番号を設定するようにしてください。
例:

Swift

1class ItemBox: Object{ 2 @objc dynamic var seq: Int = 0 3 @objc dynamic var name: String = "" 4 5 override static func primaryKey() -> String? { 6 return "seq" 7 } 8} 9

ItemBoxに登録されるデータのイメージ

1レコード目:  seq=0  name="りんご" 2レコード目:  seq=1  name="みかん" 3レコード目:  seq=2  name="ぶどう" ...

投稿2020/01/18 16:51

suhi

総合スコア28

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Atsuya-11

2020/01/19 07:43

ご回答ありがとうございます、上記方法を試したのですが --- try!' expression unexpectedly raised an error: Error Domain=io.realm Code=1 "Primary key property 'ItemBox.seq' has duplicate values after migration." UserInfo={NSLocalizedDescription=Primary key property 'ItemBox.seq' has duplicate values after migration., Error Code=1} --- このようなエラーが出てしまいます。 重複しているとはどういうことなのでしょうか。
suhi

2020/01/19 12:53

seqには他のレコードと重複しない値を設定してください。 また、Realmでは今回のようにモデル定義に変更を加えたら、「モデル定義が変わったよ」を明示的に宣言してやる必要があります(=マイグレーション)。 以下のURLなどを参考に、AppDelegateクラスに追記してみてください。 https://rara-world.com/%E3%80%90swift%E3%83%BBios%E9%96%8B%E7%99%BA%E3%80%91realm%E3%81%AE%E3%83%9E%E3%82%A4%E3%82%B0%E3%83%AC%E3%83%BC%E3%82%B7%E3%83%A7%E3%83%B3%E3%81%A7%E3%82%AB%E3%83%A9%E3%83%A0%E3%82%92%E8%BF%BD/
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問