gpt4 book ai didi

ios - 后端在第一次点击后不更新,并在连续点击后获取先前的值

转载 作者:行者123 更新时间:2023-11-30 13:37:57 30 4
gpt4 key购买 nike

我正在使用 Swift 开发一个“待办事项”应用,并使用 Firebase 作为后端。

第一次点击我的复选框以表明任务已完成时,UI 会更新并且变量应变为 true(出现复选标记),但 firebase 和该项目的 bool 值的本地实例不会更新为错误的。第二次点击后,UI 继续具有正常功能(复选标记消失);但 firebase 和本地实例都更新为 true。从那时起,接下来的点击将被反转(True 表示没有复选标记,False 表示复选标记)。当我在 Xcode 中停止模拟器并重新运行时,加载的值和 UI 是正确的。直到我尝试点击复选标记,我才再次获得不正确的功能。 Firebase 仅在用户界面中第二次点击和更改后更新。我只包含与复选框相关的代码。我认为问题发生在 doneHit 函数中,但我不太确定为什么会发生。

请帮忙。如果有更简单的方法来解决这个问题,那也会很有帮助。

protocol TaskCellDelegate {
func doneHit(cell : TaskCell)
}

class TaskCell : UITableViewCell {

var delegate : TaskCellDelegate?

@IBOutlet weak var label: UILabel!
@IBOutlet weak var checkBox: CheckBox!
@IBOutlet weak var detailLabel: UILabel!


override func awakeFromNib() {
super.awakeFromNib()
checkBox.addTarget(self, action: "buttonClicked:", forControlEvents: UIControlEvents.TouchUpInside)
}


func buttonClicked(sender:UIButton) {
delegate?.doneHit(self)

}

}


class CheckBox: UIButton {

//images
let checkedImage = UIImage(named: "checkedbox")
let unCheckedImage = UIImage(named: "uncheckedbox")


//bool propety
var isChecked:Bool = false{
didSet {
if isChecked == true{
self.setImage(checkedImage, forState: .Normal)
}
else {
self.setImage(unCheckedImage, forState: .Normal)
}
}
}


override func awakeFromNib() {
self.addTarget(self, action: "buttonClicked:", forControlEvents: UIControlEvents.TouchUpInside)
}



func buttonClicked(sender:UIButton) {
if(sender == self){
if isChecked == false {
isChecked = true
} else {
isChecked = false
}
}
}


}

func doneHit(cell:TaskCell) {
if let ip = tableView.indexPathForCell(cell) {
var task = tasks[ip.row]
task.done = cell.checkBox.isChecked
if task.done == true {
task.completedBy = "Completed by: \(self.user)"
cell.label.textColor = UIColor.grayColor()
}
else {
task.completedBy = ""
cell.label.textColor = UIColor.blackColor()
}
let taskNameRef = self.ref.childByAppendingPath("tasks/\(task.title)")
let completedByData = ["completedBy": "\(self.user)"]
let doneData = ["done": task.done]
taskNameRef.updateChildValues(completedByData)
taskNameRef.updateChildValues(doneData)

}
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("TaskCell", forIndexPath: indexPath) as! TaskCell

// Configure the cell...
cell.selectionStyle = .None
let idx = tasks[indexPath.row]
if let label = cell.viewWithTag(1) as? UILabel {
label.text = idx.title
if idx.done == true {
label.textColor = UIColor.grayColor()
} else {
label.textColor = UIColor.blackColor()
}
if let checkBox = cell.viewWithTag(2) as? CheckBox {
checkBox.isChecked = idx.done
}
if let userCompleted = cell.viewWithTag(3) as? UILabel {
if idx.done == true {
userCompleted.text = "Completed By: \(idx.completedBy)"
}
else {
userCompleted.text = ""
}
}
}
print("Task.done is: \(idx.done)")
print("isChecked is:\(cell.checkBox.isChecked)")
cell.delegate = self

return cell
}

最佳答案

三天后我自己弄清楚了。我废弃了 Checkbox 类,并将复选框变成了 UIImageView 并添加了手势识别器。剩下的就是将 Checkbox 逻辑移至 TaskTVC 类的 didHit 方法下。

关于ios - 后端在第一次点击后不更新,并在连续点击后获取先前的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35880521/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com