我有一个带有几个数据单元的TableView,每个单元格中有3个标签。
如何使用indexPath
将所有3个label.text保存到另一个变量中let indexPath = self.tableView.indexPathForSelectedRow
这是完整的代码 我实际上在另一篇文章中问过变量"限制"在.observe之后变为null。 所以我想我是否可以直接从细胞中获取数据。
import UIKit
import Firebase
import FirebaseDatabase
struct limitStruct{
var name : String!
var today : String!
var limit : String!
}
class CalcViewController: UITableViewController {
var limits = [limitStruct]()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
navigationController?.navigationBar.barTintColor = UIColor.black
self.title = "Calculation"
navigationController!.navigationBar.titleTextAttributes =
[NSForegroundColorAttributeName: UIColor.white]
let databaseReference = FIRDatabase.database().reference()
databaseReference.child("Limit").queryOrderedByKey().observe(.childAdded, with: {
snapshot in
var snapshotValue = snapshot.value as? NSDictionary
let name = snapshotValue!["name"] as? String
snapshotValue = snapshot.value as? NSDictionary
let today = snapshotValue!["today"] as? String
snapshotValue = snapshot.value as? NSDictionary
let limit = snapshotValue!["limit"] as? String
snapshotValue = snapshot.value as? NSDictionary
self.limits.insert(limitStruct(name:name, today:today, limit: limit), at: self.limits.count)
self.tableView.reloadData()
})
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return limits.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Limit")
let label1 = cell?.viewWithTag(1) as! UILabel
label1.text = limits[indexPath.row].name
let label2 = cell?.viewWithTag(2) as! UILabel
label2.text = limits[indexPath.row].today
let label3 = cell?.viewWithTag(3) as! UILabel
label3.text = limits[indexPath.row].limit
return cell!
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if segue.identifier == "showDetails"{
let svc = segue.destination as! CirSliderViewController;
if let indexPath = self.tableView.indexPathForSelectedRow{
// svc.RsegueData =
}
}
}
}
答案 0 :(得分:0)
您真的不想使用viewWithTag()
。处理此问题的最佳方法是使用数据模型对象的属性
UITableViewCell
class LimitCell: UITableViewCell {
var limit: Limit {
didSet {
// configureCell()
}
}
}
然后在你的视图控制器中:
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Limit", forIndex: indexPath) as! LimitCell
cell.limit = limits[indexPath.row]
return cell
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let svc = segue.destination as? CirSliderViewController, cell = sender as? LimitCell {
svc.RsegueData = cell.limit
}
}
答案 1 :(得分:-1)
您似乎正在使用回调来获取数据。数据是来自服务器还是存储在本地?
1)如果数据来自服务器,则代码无法保证var limits
在调用func prepare
时已获得数据。
2)如果数据存储在本地,并且只有limit
为零,则必须检查是否正确地将limits[indexPath.row].limit
分配给limits
到单元格。(是否为零)在这一刻?)我认为问题出在func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
,其中limit
已保存。
顺便说一下,实施func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
的更实际有效的方法是:
假设您的自定义单元格为LimitCell
,并且有三个UIL用户:var label1
,var label2
,var label3
。
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Limit") as! LimitCell
cell.label1.text = limits[indexPath.row].name
cell.label2.text = limits[indexPath.row].today
cell.label3.text = limits[indexPath.row].limit
return cell
}