2016-11-18 1 views
0

Ich kann nur nicht scheinen, es richtig zu machen, was die Benennung meiner Header betrifft.Swift: TitleForHeaderInSection Problem mit der Ausführung

Wenn Sie sich fragen, worum es in meinem Modell geht - es ist im Grunde ein Wörterbuch mit schönen Orten, alphabetisch geschrieben.

Kann mir jemand helfen, weil ich nicht wirklich herausfinden kann, was ich falsch mache?

import UIKit 

class PlacesTableViewController: UITableViewController { 

    // MARK: - Table view data source 

    override func numberOfSections(in tableView: UITableView) -> Int { 
     return model.places.count 
    } 

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
     switch section { 
     case 0: return (model.places["A"]!.count) 
     case 1: return (model.places["B"]!.count) 
     case 2: return (model.places["C"]!.count) 
     case 3: return (model.places["F"]!.count) 
     case 4: return (model.places["G"]!.count) 
     case 5: return (model.places["H"]!.count) 
     case 6: return (model.places["M"]!.count) 
     case 7: return (model.places["N"]!.count) 
     case 8: return (model.places["P"]!.count) 
     case 9: return (model.places["R"]!.count) 
     case 10: return (model.places["S"]!.count) 
     case 11: return (model.places["T"]!.count) 
     case 12: return (model.places["V"]!.count) 
     case 13: return (model.places["Y"]!.count) 
     case 14 : return (model.places["Z"]!.count) 
     default: return 1 
     } 
    } 

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
     let cell = tableView.dequeueReusableCell(withIdentifier: "PlacesCell", for: indexPath) 

     switch indexPath.section { 
     case 0: cell.textLabel?.text = model.places["A"]?[indexPath.row] 
     case 1: cell.textLabel?.text = model.places["B"]?[indexPath.row] 
     case 2: cell.textLabel?.text = model.places["C"]?[indexPath.row] 
     case 3: cell.textLabel?.text = model.places["F"]?[indexPath.row] 
     case 4: cell.textLabel?.text = model.places["G"]?[indexPath.row] 
     case 5: cell.textLabel?.text = model.places["H"]?[indexPath.row] 
     case 6: cell.textLabel?.text = model.places["M"]?[indexPath.row] 
     case 7: cell.textLabel?.text = model.places["N"]?[indexPath.row] 
     case 8: cell.textLabel?.text = model.places["P"]?[indexPath.row] 
     case 9: cell.textLabel?.text = model.places["R"]?[indexPath.row] 
     case 10: cell.textLabel?.text = model.places["S"]?[indexPath.row] 
     case 11: cell.textLabel?.text = model.places["T"]?[indexPath.row] 
     case 12: cell.textLabel?.text = model.places["V"]?[indexPath.row] 
     case 13: cell.textLabel?.text = model.places["Y"]?[indexPath.row] 
     case 14: cell.textLabel?.text = model.places["Z"]?[indexPath.row] 
     default: break 
     } 
     return cell 
    } 

    override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? { 
     let cell = tableView.dequeueReusableCell(withIdentifier: "HeaderCell") 
     switch section { 
     case 0: cell?.textLabel?.text = "A" 
     case 1: cell?.textLabel?.text = "B" 
     case 2: cell?.textLabel?.text = "C" 
     case 3: cell?.textLabel?.text = "F" 
     case 4: cell?.textLabel?.text = "G" 
     case 5: cell?.textLabel?.text = "H" 
     case 6: cell?.textLabel?.text = "M" 
     case 7: cell?.textLabel?.text = "N" 
     case 9: cell?.textLabel?.text = "P" 
     case 10: cell?.textLabel?.text = "R" 
     case 11: cell?.textLabel?.text = "S" 
     case 12: cell?.textLabel?.text = "T" 
     case 13: cell?.textLabel?.text = "Y" 
     case 14: cell?.textLabel?.text = "Z" 
     default: break 
     } 

     return String(describing: cell) 
    } 
} 
+0

Im Gegensatz zu dem, was Sie vielleicht denken, ist eine UITableView-Header-Ansicht vom Typ UITableViewHeaderFooterView und nicht UITableViewCell. Sie sollten es von einer Feder laden, anstatt dequeReuseableCell zu verwenden. Verwenden Sie alternativ UICollectionView, das über wiederverwendbare Kopf-/Fußzeilenansichten in Form von UICollectionReusableView verfügt. –

+0

@JoshHomann Das OP verwendet nicht 'viewForHeader' oder' viewForFooter'. Das OP verwendet 'titleForHeader ...', so dass nur eine einfache Zeichenfolge benötigt wird. – rmaddy

Antwort

0

Du bringst mich um Kleinigkeiten. ;)

import UIKit 

class PlacesTableViewController: UITableViewController { 

    let letters = ["A", "B", "C", "F", "G", "H", "M", "N", "P", "R", "S", "T", "V", "Y", "Z"] 

    // MARK: - Table view data source 

    override func numberOfSections(in tableView: UITableView) -> Int { 
     return model.places.count 
    } 

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
     let letter = letters[section] 
     return model.places[letter]?.count ?? 1 
    } 

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
     let cell = tableView.dequeueReusableCell(withIdentifier: "PlacesCell", for: indexPath) 
     let letter = letters[indexPath.section] 
     cell.textLabel?.text = model.places[letter]?[indexPath.row] 
     return cell 
    } 

    override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? { 
     let letter = letters[section] 
     return letter 
    } 
} 

EDIT:

Hier finden Sie aktuelle UITableViewDelegate für weitere Informationen.

Um die tatsächliche Header-Ansicht zu bearbeiten, möchten Sie speziell viewForHeaderInSection verwenden.

+0

Vielen Dank! :) Kannst du eine Follow-up-Frage beachten? Wie würde ich die Abschnitte dann stylen? Wie ändert man die Schriftgröße oder ändert den Hintergrund usw.? –

+0

Kein Problem. Überprüfen Sie meine Bearbeitung. – Frankie

0

Neben der Tatsache müssen Sie wahrscheinlich überdenken, wie Ihr Modell funktioniert. titleForHeaderInSection möchte nur einen String und UIKit den Rest. Also gib nicht String(describing: cell) zurück, denn das ist nur der Name der Zelle. Sie müssen die Zeichenfolge zurückgeben, auf die Sie textLabel festlegen möchten. So halten Sie den Schalter aber für jeden Fall statt

cell?.textLabel?.text = "{Letter}"

dies tun:

return "{Letter}"

und entfernen Sie die let Zelle ... Zeile und die letzte Rückleitung

Verwandte Themen