2016-09-22 2 views
0

Я реализовал tableView, чтобы сделать свертывание и расширение строк; это мой класс (я последовал this учебник):NSInternalInconsistencyException update Tableview

import UIKit 
import ChameleonFramework 

class AllTeamChantsController: UIViewController, UITableViewDataSource, UITableViewDelegate 
{ 
    var ponte: String? 
    var sections: [Section]! 

    @IBOutlet weak var tableView: UITableView! 

    override func viewDidLoad() 
    { 
     super.viewDidLoad() 

     if let stringaPonte = ponte 
     { 
      title = stringaPonte 
     } 

     sections = [Section(name: "Derby", items: ["coro", "coro", "coro", "coro"]), 
        Section(name: "Personagi", items: ["coro", "coro", "coro", "coro"]), 
        Section(name: "Cori", items: ["coro", "coro", "coro", "coro"])] 
    } 

    override func didReceiveMemoryWarning() 
    { 
     super.didReceiveMemoryWarning() 
    } 

    func numberOfSections(in tableView: UITableView) -> Int 
    { 
     return 1 
    } 

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
    { 
     var count = sections.count 

     for section in sections 
     { 
      count += section.items.count 
     } 

     return count 
    } 

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell 
    { 
     let section = getSectionIndex(indexPath.row) 
     let row = getRowIndex(indexPath.row) 

     if row == 0 
     { 
      let cell = tableView.dequeueReusableCell(withIdentifier: "header") as! AllTeamChantsHeader 
      cell.titleLabel.text = sections[section].name 
      cell.toogleButton.tag = section 
      cell.toogleButton.setTitle(sections[section].collapsed! ? "+" : "-", for: UIControlState()) 
      cell.toogleButton.addTarget(self, action: #selector(AllTeamChantsController.toggleCollapse), for: .touchUpInside) 

      return cell 
     } 
     else 
     { 
      let cell = tableView.dequeueReusableCell(withIdentifier: "cell") as UITableViewCell! 
      cell?.textLabel?.text = sections[section].items[row - 1] 

      return cell! 
     } 
    } 


    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat 
    { 
     let section = getSectionIndex((indexPath as NSIndexPath).row) 
     let row = getRowIndex((indexPath as NSIndexPath).row) 

     if row == 0 
     { 
      return 50.0 
     } 

     return sections[section].collapsed! ? 0 : 44.0 
    } 

    // MARK: - Event Handlers 

    func toggleCollapse(_ sender: UIButton) { 
     let section = sender.tag 
     let collapsed = sections[section].collapsed 

     // Toggle collapse 
     sections[section].collapsed = collapsed! 

     let indices = getHeaderIndices() 

     let start = indices[section] 
     let end = start + sections[section].items.count 

     tableView.beginUpdates() 
     for i in start ..< end + 1 { 
      tableView.reloadRows(at: [IndexPath(row: i, section: 1)], with: .automatic) 
     } 
     tableView.endUpdates() 
    } 

    // MARK: - Helper Functions 

    func getSectionIndex(_ row: NSInteger) -> Int { 
     let indices = getHeaderIndices() 

     for i in 0..<indices.count { 
      if i == indices.count - 1 || row < indices[i + 1] { 
       return i 
      } 
     } 

     return -1 
    } 

    func getRowIndex(_ row: NSInteger) -> Int { 
     var index = row 
     let indices = getHeaderIndices() 

     for i in 0..<indices.count { 
      if i == indices.count - 1 || row < indices[i + 1] { 
       index -= indices[i] 
       break 
      } 
     } 

     return index 
    } 

    func getHeaderIndices() -> [Int] { 
     var index = 0 
     var indices: [Int] = [] 

     for section in sections { 
      indices.append(index) 
      index += section.items.count + 1 
     } 

     return indices 
    } 
} 

Проблема заключается в том, что, когда я прикасаюсь тумблер моего приложения авария и Xcode отправить мне это сообщение в консоли

«Нагрузочное приложение из-за uncaught exception «NSInternalInconsistencyException», причина: «попытаться удалить строку X из раздела 1, но перед обновлением осталось только 1 раздел».

Может ли кто-нибудь помочь мне решить эту проблему? Я просто попытался осматривать методы numberOfRowsInSection и toggleCollapse, но я не нашел никаких проблем.

ответ

0

Это ошибка:

for i in start ..< end + 1 { 
      tableView.reloadRows(at: [IndexPath(row: i, section: 1)], with: .automatic) 
     } 

очевидно, если я удалю первый раздел, я должен перезагрузить indexPath в разделе 0, а не 1! это решает проблему!

0

Я думаю, ваша ошибка

var count = sections.count // wrong 

    for section in sections 
    { 
     count += section.items.count 
    } 

так он будет возвращать 15 строк, но он должен быть вернуться 12 строк так попробовать

var count = 0 then calculate all section count 

вернет 12, что является правильным надеюсь, что это поможет

+0

Благодарим парня, но это не ошибка: эти «секции» не являются секцией TableView, но только 3 ячейки, затрагивающие их, сбрасывают или расширяют другие ячейки. –

 Смежные вопросы

  • Нет связанных вопросов^_^