ios - Swift 将 TableView 分成两部分

标签 ios swift uitableview tableview uitableviewsectionheader

我正在用 Swift 为我的学校做一个项目,我在 TableView 中显示数据。它显示两天的信息,实际日期和第二天。现在我想每天将表格分成两个部分。如果可以使用带有每个部分日期的部分标题。 如果我已经拥有包含数据的 TableView,我该怎么做。 此致。 ;)

    func parser(_ parser: XMLParser, didStartElement elementName: String, namespaceURI: String?, qualifiedName qName: String?, attributes attributeDict: [String : String] = [:]) {

    thisName = elementName

}

func parser(_ parser: XMLParser, didEndElement elementName: String, namespaceURI: String?, qualifiedName qName: String?) {
    if elementName == "element" {
        var myPlan = Plan()
        myPlan.klasse = planKlasse
        myPlan.raum = planRaum
        myPlan.vertreter = planVertreter
        myPlan.art = planArt
        myPlan.fach = planFach
        myPlan.stunde = planStunde
        myPlan.lehrer = planLehrer
        myPlan.datum = planDatum

        print(myPlan)
        tableViewDataSource.append(myPlan)


    }
}

func parser(_ parser: XMLParser, foundCharacters string: String) {


    let data = string.trimmingCharacters(in: CharacterSet.whitespacesAndNewlines)

    if data.count != 0 {
        switch thisName {
        case "klasse": planKlasse = data
        case "vertreter": planVertreter = data
        case "raum": if data.hasPrefix("SN") { planRaum = "SNÜRN" } else {planRaum = data}
        case "art": planArt = data
        case "fach": planFach = data
        case "stunde": planStunde = data
        case "lehrer": planLehrer = data; if (data.isEmpty) { planLehrer = "-"}
        case "datum": planDatum = data
        default:
            break
        }

    }
}

func parser(_ parser: XMLParser, parseErrorOccurred parseError: Error) {
    print("failure error: ", parseError)
}







func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    return 80
}


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    if (searchController.isActive && searchController.searchBar.text != "") {
        return filteredElements.count
    } else {
        return tableViewDataSource.count
    }
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let myCell = tableView.dequeueReusableCell(withIdentifier: "reuseCell", for: indexPath)

    var element: Plan

    if (searchController.isActive && searchController.searchBar.text != "") {
        element = filteredElements[indexPath.row]
        myCell.backgroundColor = UIColor.orange
    } else {
        element = tableViewDataSource[indexPath.row]
        myCell.backgroundColor = UIColor.white
    }

    let myKlasseLabel = myCell.viewWithTag(11) as! UILabel
    let myVertreterLabel = myCell.viewWithTag(12) as! UILabel
    let myRaumLabel = myCell.viewWithTag(13) as! UILabel
    let myArtLabel = myCell.viewWithTag(15) as! UILabel
    let myFachLabel = myCell.viewWithTag(14) as! UILabel
    let myStundeLabel = myCell.viewWithTag(16) as! UILabel
    let myLehrerLabel = myCell.viewWithTag(17) as! UILabel
    let myDatumLabel = myCell.viewWithTag(18) as! UILabel


    myKlasseLabel.text = element.klasse
    myVertreterLabel.text = element.vertreter
    myRaumLabel.text = element.raum
    myArtLabel.text = element.art
    myFachLabel.text = element.fach
    myStundeLabel.text = element.stunde + "."
    myLehrerLabel.text = "(" + element.lehrer + ")"
    myDatumLabel.text = element.datum


    if (element.art == "Klausur") {
        myFachLabel.text = "-"
        myLehrerLabel.text = "-"
    }

    if ((defaults.object(forKey: "klasseWahlDef")) as? String != nil) {

        if (tableViewDataSource[indexPath.row].klasse == (defaults.object(forKey: "klasseWahlDef")) as? String) {
        myCell.backgroundColor = UIColor.orange
        } else if (tableViewDataSource[indexPath.row].vertreter == (defaults.object(forKey: "LehrerDef")) as? String) {
           myCell.backgroundColor = UIColor.orange
        }
    }

    if tableViewDataSource[indexPath.row].datum != "hi" {

        let dateFormatterGet = DateFormatter()
        dateFormatterGet.dateFormat = "yyyy-MM-dd"

        let dateFormatterPrint = DateFormatter()
        dateFormatterPrint.locale = Locale(identifier: "de_DE")
        dateFormatterPrint.dateFormat = "E dd.MM.yyyy"


        if let date = dateFormatterGet.date(from: element.datum){
            //print(dateFormatterPrint.string(from: date))
            myDatumLabel.text = dateFormatterPrint.string(from: date)
        }
        else {
            print("There was an error decoding the string")
        }
    }
    return myCell

}

最佳答案

您必须定义要显示的部分的数量:

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

然后您必须定义要在每个部分中显示的行数:

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    if section == 0 {
        //return number of rows in first section
    }
    else {
        //return number of rows in second section
    }
}

如果你想创建自定义标题,那么你可以使用这个函数:

func tableView(tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
    // return custom header view
}

但是,如果您只想在标题中显示文本,您可以使用默认的并且只使用 titleForHeaderInSection 函数。

当然,您还必须为单元格返回正确的 View 。如果你想检查节号,你可以简单地调用

indexPath.section

关于ios - Swift 将 TableView 分成两部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52260485/

相关文章:

ios - 在不同 View Controller 中使用时返回 nil 值的全局变量

ios - 移动应用程序在后台时的 Websockets 消息传递

ios - 如何查找并修复崩溃原因

iOS 在 swift 主 StoryBoard 之前创建一个欢迎页面

swift - Swift 的 catch block 前面的 _ 下划线是什么?

ios - 当用户向 UITableView 添加行时,返回应用程序时新行不是 "stay"

iphone - 在Three20 TTLauncherView中更改页面控制点的颜色

ios - 由于UIRefreshControl而导致异常

swift - 在TableView Swift 4中显示Firebase数据

ios - 在 UIScrollView 中约束 UITableView