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

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

ただいまの
回答率

90.60%

  • Swift

    7039questions

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

  • Xcode

    4000questions

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

  • iOS

    3902questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • TableView

    110questions

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

cellのデリートについて(エラーコード: Index out of range)

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 133

haruka-t

score 77

struct Cell {
  var detail: [String]
  var lightswipe: Bool//detail
}

import UIKit

class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate{

  @IBOutlet weak var mytableView: UITableView!

  //構造体
  var titles: [String] = [] // title用
  var products: [Cell] = []//detail


  func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    // 全データの合計
    return titles.count + products.count
  }

  func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = UITableViewCell()
    let index = Int(floor(Double(indexPath.row / 2)))
    //セルタップ時のハイライトについて
    cell.selectionStyle = .none
    // title行
    if indexPath.row % 2 == 0 {

      guard titles.count > 0 else {
        return cell
      }


      let title = titles[index]
      cell.textLabel?.text = title
      //センター寄せ
      cell.textLabel!.textAlignment = NSTextAlignment.center
      cell.backgroundColor = UIColor(red: 0.0, green: 0.8, blue: 1.0, alpha: 0.3)

    // detail行
    } else {
      cell.backgroundColor = UIColor.lightGray
      let item = products[index]

      guard item.detail.count > 0 else {
        return cell
      }

      var labels: [UILabel] = []

      //labelについて
      for i in item.detail {
        let label = UILabel()
        label.backgroundColor = UIColor(red: 0.0, green: 0.8, blue: 0.9, alpha: 0.2)
        label.text = i


        // textLabel という名前の変数に格納された UILabel にフォントサイズの自動調整を設定します。
        label.adjustsFontSizeToFitWidth = true
        label.minimumScaleFactor = 10.0
        //丸みに対して
        label.layer.cornerRadius = 5
        label.layer.masksToBounds = true
        cell.contentView.addSubview(label)
        labels.append(label)
      }

      var preLabel: UILabel? = nil
      for l in labels {

        l.translatesAutoresizingMaskIntoConstraints = false
        if (preLabel == nil) {
          l.leftAnchor.constraint(equalTo: cell.contentView.leftAnchor, constant: 12).isActive = true
        } else {
          l.leftAnchor.constraint(equalTo: preLabel!.rightAnchor, constant: 20).isActive = true
        }
        cell.contentView.heightAnchor.constraint(equalTo: l.heightAnchor, multiplier: 1).isActive = true
        preLabel = l
      }

    }

    return cell
  }


  @IBAction func addcellbtr(_ sender: Any) {

    alertnormal()
  }

  //cellの削除について
  func tableView(_ tableView: UITableView, editingStyleForRowAt indexPath: IndexPath) -> UITableViewCellEditingStyle {
    //return products[indexPath.row].detail ? .delete : .none
    if mytableView.isEditing {
      return .delete
    }
    return .none
  }
  //cellの削除について
  func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
    if editingStyle == .delete {
      self.deleteRow(at: indexPath)
    }
  }

  func deleteRow(at indexPath: IndexPath) {

    self.titles.remove(at: indexPath.row)
    mytableView.deleteRows(at: [indexPath], with: .fade)//
  }

  override func viewDidLoad() {
    super.viewDidLoad()
    mytableView.delegate = self
    mytableView.dataSource = self
    mytableView.reloadData()
  }



  override func didReceiveMemoryWarning() 
}

 やりたいこと

titleとなるセルとdetailとなるセルをセットにしてセルをデリート出来る様にしたい。

出来たこと
titileとなるセルはデリートすることが出来た。

self.titles.remove(at: indexPath.row)

困っていること
titleとなるセルとdetailとなるセルを同時にデリートしたいが下記コードを追加するとIndex out of rangeが起きてしまう。エラーコードの意味は理解しているがどうコーディングすればいいか分からなくて困っています。

self.detail.remove(at: indexPath.row)


またdetailセルはtitleセルの下のセルなので下記の様にもしてみたが出来ませんでした。

self.titles.remove(at: indexPath.row + 1)
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

 self.titles.remove(at: indexPath.row)
    self.products.remove(at: indexPath.row)
    mytableView.reloadData()


上記の様にしたところ解決する事が出来ました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.60%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Swift

    7039questions

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

  • Xcode

    4000questions

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

  • iOS

    3902questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • TableView

    110questions

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