我将viewController中的参数发送到customCell。我的自定义单元格有一个textField。在我的viewController中,我有一个字符串变量,用于在textField中存储值,因为这个值我将发送到休息服务。
MyCustomCell
customCell: TableViewCell: {
var data: String?
@IBOutlet weak var textField: UITextField!
override func awakeFromNib() {
super.awakeFromNib()
textField.delegate = self
}
func setData(data: inout String) {
self.data = data
}
}
extension customCell: UITextFieldDelegate {
func textFieldDidEndEditing(_ textField: UITextField) {
data = textField.text ?? ""
}
}
MyViewController
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "customCell", for: indexPath) as! customCell
cell.setData(data: &data.email)
return cell
}
当我将引用发送到customCell时,我在textFieldDidEndEditing方法中丢失了引用。
答案 0 :(得分:2)
不要那样做。
使用class
创建数据模型。类是引用类型
class Model {
var name : String
var email : String
init(name: String, email: String) {
self.name = name
self.email = email
}
}
声明数据源数组
var models = [Model]()
在单元格中声明模型的属性(顺便以类名开头的大写字母)
class CustomCell: TableViewCell {
@IBOutlet weak var textField: UITextField!
var model: Model! {
didSet {
textField.text = model.email
}
}
override func awakeFromNib() {
super.awakeFromNib()
textField.delegate = self
}
}
extension CustomCell: UITextFieldDelegate {
func textFieldDidEndEditing(_ textField: UITextField) {
model.email = textField.text ?? ""
}
}
在cellForRow中将模型传递给单元格
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "customCell", for: indexPath) as! CustomCell
cell.model = models[indexPath.row]
return cell
}
由于引用语义,模型中的值被保留。
答案 1 :(得分:1)
以下情况并非如您所愿:
func setData(data: inout String) {
self.data = data
}
当然,您传递给此方法的String
是inout
,但这不会改变您的单元格的String
属性是值类型,因此您的{{1}有效地成为一个新实例。
从根本上说,您正在尝试使用self.data
来实现引用类型语义,这是一种值类型。
你可以扭曲自己来实现这一点,但我不鼓励你这样做。对单元采用闭包或协议委托或反应模式来通知视图控制器或变更模型会更清晰。