#swift #uitableview #sum #add
#swift #uitableview #сумма #Добавить
Вопрос:
я хочу, чтобы мой swift-код объединял все ячейки tableview вместе и преобразовывал его из строки в int. Код должен быть вызван из функции view did load. При суммировании всех меток общее количество должно быть равно 3. Посмотрите на мой комментарий в view did load для получения дополнительной информации. В коде не используются раскадровки.
import UIKit
class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
var numberOfRows = 3
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { numberOfRows }
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { 118 }
var tableView = UITableView()
var selectedIndexPath = IndexPath(row: 0, section: 0)
override func viewDidLoad() {
super.viewDidLoad()
setTableVIew()
//print the sum of the labels added togther on the tableview cells
}
func setTableVIew(){
let VCframe = view.frame
let height = VCframe.height * 0.8
let widthx = VCframe.width
tableView.frame = CGRect(x: 10, y: 0, width: widthx - 20, height: height)
tableView.delegate = self
tableView.dataSource = self
view.addSubview(tableView)
tableView.register(customtv.self, forCellReuseIdentifier: "cell")
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! customtv
cell.lbl.text = "(indexPath.row)"
return cell
}
}
class customtv: UITableViewCell {
lazy var backView : UIView = {
let view = UIView(frame: CGRect(x: 10, y: 6, width: self.frame.width , height: 110))
view.backgroundColor = .green
print(self.frame.width)
return view
}()
override func layoutSubviews() {
backView.clipsToBounds = true
backView.frame = CGRect(x: 0, y: 6, width: bounds.maxX , height: 110)
}
lazy var lbl : UILabel = {
let press = UILabel(frame: CGRect(x: 0, y: 3, width: 120 , height: 50))
press.backgroundColor = .yellow
press.text = String("1")
return press
}()
override func setSelected(_ selected: Bool, animated: Bool) {
super.setSelected(animated, animated: true)
addSubview(backView)
backView.addSubview(lbl)
}
}
Комментарии:
1. Вы уже получили решение?
Ответ №1:
Вот как вы это делаете:
override func viewDidLoad() {
super.viewDidLoad()
setTableView()
calculateSum()
}
func calculateSum() {
var sum = 0
for row in 0..<numberOfRows {
let indexPath = IndexPath(row: row, section: 0)
let cell = tableView.cellForRow(at: indexPath) as! CustomTableViewCell
sum = Int(cell.label.text ?? "") ?? 0
}
print(sum)
}
Примечание: Сделайте имена классов и объектов согласованными, например: lbl
-> label
и customtv
-> CustomTableViewCell
, как я указал выше. Даже имена методов setTableVIew
-> setTableView
. Было бы лучше, если бы вы использовали SwiftLint.
Комментарии:
1. Неустранимая ошибка: неожиданно обнаружено значение nil при развертывании необязательного значения. В let ячейка = tableview
2. Вы должны обновить
customtv
вcellForRow
методе какCustomTableViewCell
.3. Попробовал то, что, по вашим словам, не имело никакого эффекта, загрузил проект, чтобы получить hub, если вы хотите посмотреть. github.com/redrock34/tableviewsum
4. Просто добавьте
tableView.reloadData()
в концеsetTableView
метода.