我从我的viewController向customCell发送一个参数。我的自定义单元有一个textField。在我的viewController中,我有一个字符串变量,用于将值存储在textField中,因为这个值将发送到rest服务。
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方法中的引用丢失了。
发布于 2018-04-04 17:23:29
别干那事。
使用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
}由于引用语义的存在,使得模型中的值得以保留。
发布于 2018-04-04 19:40:12
以下不是你所认为的那样:
func setData(data: inout String) {
self.data = data
}当然,传递给该方法的String是inout,但这并不改变这样一个事实,即单元格的String属性是值类型,因此self.data实际上变成了一个新实例。
从根本上说,您正在尝试使用String来实现引用类型语义,这是一种值类型。
你可以扭曲自己来实现这一目标,但我会劝阻你不要这样做。如果采用闭包或协议委托或反应模式来通知视图控制器或更改模型,将会更加清晰。
https://stackoverflow.com/questions/49656660
复制相似问题