我想使用TableViewCell
从TextFields
获取所有值,但是我不知道如何通过单击按钮来做到这一点。
如果我点击按钮Add
,则可以添加新行。这样我就可以根据需要创建任意多行。
我的代码在这里:
struct Section {
let title: String
var rows: [String]
}
class SettingsScheduleAndPricesViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, UITextFieldDelegate {
var hall: Halls?
var sections = [Section]()
override func viewDidLoad() {
super.viewDidLoad()
sections = [Section(title: "Day of week", rows: []),
Section(title: "Second section", rows: [""]),
Section(title: "Third section", rows: [""])]
}
// MARK: - TableView
func numberOfSections(in tableView: UITableView) -> Int {
return sections.count
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return sections[section].rows.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
if indexPath.section == 0 {
...
} else if indexPath.section == 1 {
let hourlyRateCell = tableView.dequeueReusableCell(withIdentifier: "hourlyRateCell", for: indexPath) as! SettingsHourlyRateCell
return hourlyRateCell
} else {
...
}
}
func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
return sections[section].title
}
func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
let frame: CGRect = tableView.frame
if section == 0 {
let headerView: UIView = UIView(frame: CGRect(x: 0, y: 0, width: frame.size.width, height: frame.size.height))
headerView.backgroundColor = #colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1)
return headerView
} else if section == 1 {
let addButton: UIButton = UIButton(frame: CGRect(x: frame.size.width - 50, y: 0, width: 50, height: 30))
addButton.backgroundColor = UIColor.clear
addButton.setTitleColor(#colorLiteral(red: 0.2588235438, green: 0.7568627596, blue: 0.9686274529, alpha: 1), for: .normal)
addButton.setTitle(NSLocalizableAdd, for: .normal)
addButton.addTarget(self, action: #selector(SettingsScheduleAndPricesViewController.addHourlyRate(sender:)), for: .touchUpInside)
let headerView: UIView = UIView(frame: CGRect(x: 0, y: 0, width: frame.size.width, height: frame.size.height))
headerView.backgroundColor = #colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1)
headerView.addSubview(addButton)
return headerView
} else {
...
}
}
@IBAction func saveBarButtonPressed(_ sender: Any) {
// here I want to get all values from my Cell from my TextFields
}
@objc func addHourlyRate(sender: UIButton) {
let newRow = ""
append(row: newRow, in: 1)
}
func append(row : String, in section: Int) {
let insertionIndex = sections[section].rows.count
sections[section].rows.append(row)
let indexPath = IndexPath(row: insertionIndex, section: section)
tableView.insertRows(at: [indexPath], with: .automatic)
}
}
class SettingsHourlyRateCell: UITableViewCell, UITextFieldDelegate {
@IBOutlet weak var rubHourTF: UITextField!
}
我的模拟器示例:
在我的示例中,我需要从三行中获取first
,second
和third
字符串文本。并附加在空白的array
或仅打印在console
中。
在方法@IBAction func saveBarButtonPressed(_ sender: Any)
中。
我找不到任何可以帮助我的东西。
答案 0 :(得分:0)
您可以为您的单元制定委托协议
protocol cellDelegate {
func buttonClicked(textFieldText: String)}
并在您的单元格中更改协议的变量
var delegate: cellDelegate?
然后点击按钮事件从变量中调用方法
delegate?.buttonClicked(textFieldText: "string you got from textField")
,然后在您的表视图中,cellForRowAt indexPath 方法设置单元格的委托,如下所示:cell.delegate = self
答案 1 :(得分:0)
TextFields可能很棘手。首先,使用数据模型和reloadData()代替如下的insertRows(at:):
@objc func addHourlyRate(sender: UIButton) {
let newRow: String = ""
secondRowText.append(newRow)
self.tableView.reloadData()
}
现在,在单元格中设置文本,并使用cellForRowAt()中的行号标记UITextField,如下所示:
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let hourlyRateCell = tableView.dequeueReusableCell(withIdentifier: "hourlyRateCell", for: indexPath) as! SettingsHourlyRateCell
hourlyRateCell.rubHourTF.text = secondRowText[indexPath.row]
hourlyRateCell.rubHourTF.tag = indexPath.row
return hourlyRateCell
}
接下来,使用UITextFieldDelegate跟踪文本字段中的任何更改,例如:
func textFieldDidEndEditing(_ textField: UITextField) {
let tableRow = textField.tag
secondRowText[tableRow] = textField.text
}
请注意,现在如何使用cellForRow()中设置的textField标记来了解textField在表中的哪一行。
答案 2 :(得分:0)
也许我的方法可以帮助某人,但是我还是设法做到了。我只是在我的button
中添加以下代码:
@IBAction func saveBarButtonPressed(_ sender: Any) {
let countRowsOne = tableView.numberOfRows(inSection: 1)
for index in 0...countRowsOne {
let indexPath = IndexPath(row: index, section: 1)
if let cell = tableView.cellForRow(at: indexPath) as? SettingsHourlyRateCell {
...
}
...
}
}
}
答案 3 :(得分:-1)
不需要标签
@IBAction func saveBarButtonPressed(_ sender: Any) {
var array = NSMutableArray()
for subview in self.tableView.subViews {
if subView.isKind(of: String(describing: SettingsHourlyRateCell.self)) {
for sView in subview {
if sView.isKind(of: String(describing: UITextField.self)) {
array.add(sView.text)
}
}
}
}
}