Swift UITableViewSections来自对象数组
我正在努力实现以下目标。我正在将xml字符串映射到tableview中。这部分工作正常,但是我也希望在tableview中创建部分。我需要LINENAME作为SectionName,节点名应该作为行位于这些节的下面。下面是它应该是什么样子的一个例子Swift UITableViewSections来自对象数组,swift,uitableview,objectmapper,uitableviewsectionheader,xmlmapper,Swift,Uitableview,Objectmapper,Uitableviewsectionheader,Xmlmapper,我正在努力实现以下目标。我正在将xml字符串映射到tableview中。这部分工作正常,但是我也希望在tableview中创建部分。我需要LINENAME作为SectionName,节点名应该作为行位于这些节的下面。下面是它应该是什么样子的一个例子 标题(第1行) 小区(节点1) 单元(节点2) 标题(第2行) 小区(节点1) 等等 有人能给我一些关于如何实现这一点的更多信息吗 提前谢谢 var LineRows: [LineRow] = [] override func vi
- 标题(第1行)
- 小区(节点1)
- 单元(节点2)
- 标题(第2行)
- 小区(节点1)
var LineRows: [LineRow] = []
override func viewDidLoad() {
super.viewDidLoad()
let xmlString = """
<?xml version="1.0" encoding="utf-8"?>
<RESULT>
<ROWSET>
<ROW>
<LINENAME>LINE1</LINENAME>
<NODENAME>NODE1</NODENAME>
<LINEID>1</LINEID>
</ROW>
<ROW>
<LINENAME>LINE1</LINENAME>
<NODENAME>NODE2</NODENAME>
<LINEID>1</LINEID>
</ROW>
<ROW>
<LINENAME>LINE2</LINENAME>
<NODENAME>NODE1</NODENAME>
<LINEID>2</LINEID>
</ROW>
</ROWSET>
</RESULT>
"""
let data = Data(xmlString.utf8) // Data for deserialization (from XML to object)
do {
let xml = try XMLSerialization.xmlObject(with: data, options: [.default, .cdataAsString])
let food = XMLMapper<LineResult>().map(XMLObject: xml)
print(food?.Linerowset?.Linerows?.first?.Linename ?? "nil")
self.LineRows = food!.Linerowset?.Linerows ?? []
self.tableView.reloadData()
// debugPrint(LineRows)
} catch {
print(error)
}
}
调试打印(行)响应:
[ApiApp.LineController.LineRow, ApiApp.LineController.LineRow, ApiApp.LineController.LineRow]
LINE1
▿ 3 elements
▿ ApiApp.LineController.LineRow #0
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE1")
- some: "LINE1"
▿ Nodename: Optional("NODE1")
- some: "NODE1"
▿ LineLineID: Optional("1")
- some: "1"
▿ ApiApp.LineController.LineRow #1
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE1")
- some: "LINE1"
▿ Nodename: Optional("NODE2")
- some: "NODE2"
▿ LineLineID: Optional("1")
- some: "1"
▿ ApiApp.LineController.LineRow #2
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE2")
- some: "LINE2"
▿ Nodename: Optional("NODE1")
- some: "NODE1"
▿ LineLineID: Optional("2")
- some: "2"
转储(行)响应:
[ApiApp.LineController.LineRow, ApiApp.LineController.LineRow, ApiApp.LineController.LineRow]
LINE1
▿ 3 elements
▿ ApiApp.LineController.LineRow #0
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE1")
- some: "LINE1"
▿ Nodename: Optional("NODE1")
- some: "NODE1"
▿ LineLineID: Optional("1")
- some: "1"
▿ ApiApp.LineController.LineRow #1
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE1")
- some: "LINE1"
▿ Nodename: Optional("NODE2")
- some: "NODE2"
▿ LineLineID: Optional("1")
- some: "1"
▿ ApiApp.LineController.LineRow #2
▿ nodeName: Optional("ROW")
- some: "ROW"
▿ Linename: Optional("LINE2")
- some: "LINE2"
▿ Nodename: Optional("NODE1")
- some: "NODE1"
▿ LineLineID: Optional("2")
- some: "2"
我会制作一个更适合您的表视图的ViewModel
struct LineSections {
let lineId: String?
let lineName: String?
let nodes: [LineRow]
}
我猜您在某个地方有var LineRows:[LineRows]=[]
作为ViewController的属性。我将使用var lineSections:[lineSections]=[]
对其进行更改
那么
不相关:以小写字母命名您的var:
let Cell
=>let Cell
等。不相关,但不要以大写字母命名您的varlet Cell=
=>let Cell=
,与结构/类的属性相同。请取消注释debugPrint(LineRows)
并将输出(即数据源结构)添加到问题中好吗?@LucaSfragara我已经添加了来自debugPrint(LineRows)和Dump(LineRows)的响应。提前谢谢!您需要为LineRows
的每个元素指定一个部分,对吗?我会重新分组行。我将使用struct-LineSection{let-lineId:String?;let-lineName:String?;let-nodes:[LineRow]}
而不是直接将当前模型放在tableView VC中,如果以后使用var-sections:[LineSection]
:NumberOfSection:sections.count
,NumberOfRowsInSection:sections[section]。nodes.count
,IndexPath处的元素:让person=sections[IndexPath.section]。nodes[IndexPath.row]
感谢构建示例。显然,这段代码给了我一个错误,它无法在下一行的作用域中找到“Sections”:self.lineSections=Dictionary(分组:行。应该是固定的,在我的操场上,我把它命名为Sections
,而不是LineSections
。你能把你操场的副本放下来吗?它一直给我带来一些非常奇怪的错误。谢谢你!现在一切都好了!
self.LineRows = food!.Linerowset?.Linerows ?? []
let rows = food?.Linerowset?.Linerows ?? []
self.lineSections = Dictionary(grouping: rows, by: { $0.lineId }).values.compactMap { LineSections(lineId: $0.first?.lineId, lineName: $0.first?.lineName, nodes: $0) }.sorted(by: { $0.lineId ?? "" < $1.lineId ?? "" }
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return lineSections[section].node.count
}
override func numberOfSections(in tableView: UITableView) -> Int {
return lineSections.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)
let person = lineSections[indexPath.section].node[indexPath.row]
cell.textLabel?.text = person.Nodename
return cell
}