每个单元格显示相应的评论和已登录用户的照片。它们已加载了解析。
现在,您要Löschen按钮删除照片和评论。
不幸的是,这不起作用。我点击按钮后,什么也没发生
不幸的是,我了解得很快,无法解决问题
查询有效,并且应用程序显示照片和Commons。查询和邮政编码:
override func viewDidLoad() {
super.viewDidLoad()
super.viewDidLoad()
let query = PFQuery(className: "Post")
query.whereKey("username", equalTo: PFUser.current()?.username)
query.findObjectsInBackground(block: { (object, error) in
if let posts = object {
for post in posts{
print(posts)
self.comments.append(post["message"] as! String)
self.imageFile.append(post["imageFile"] as! PFFile)
self.tableView.reloadData()
}
DispatchQueue.main.async {
self.tableView.reloadData()
}
}
})
}
这是我尝试过的“删除”功能代码:
@IBAction func remove(_ sender: Any) {
print("Entered remove")
let query = PFQuery(className: "Post")
query.whereKey("username", equalTo: PFUser.current()?.username)
query.findObjectsInBackground(block: { (object, error) in
if let posts = object {
print(posts)
for post in posts{
print(posts)
if let message = post["message"] as? String, let image = post["imageFile"] as? PFFile {
print("message and image read", message, image)
if let messageIndex = self.comments.index(of: message), let imageIndex = self.imageFile.index(of:image) {
self.comments.remove(at: messageIndex)
self.imageFile.remove(at: imageIndex)
}
}
self.tableView.reloadData()
}
DispatchQueue.main.async {
self.tableView.reloadData()
}
}
})
}
输出:
我没有收到错误消息,也没有删除任何内容。 谢谢您的帮助
答案 0 :(得分:2)
您无权访问当前索引的where和对象id。 这样一来,您就可以轻松删除。
实现删除功能的更简单方法是为您的消息设置一个objectId数组:
self.ids.append(post.objectId)
要删除它时:
let query = PFQuery(className: "Post")
query.whereKey("objectId", equalTo: self.ids.index(of: indexPath.row))
// Make a query in background to only get the object that you want to delete
query.getFirstObjectInBackgroundWithBlock {
(object: PFObject?, error: NSError?) -> Void in
if error != nil || object == nil {
print("The getFirstObject request failed.")
} else if let object = object {
print("Successfully retrieved the object.")
object.deleteInBackground()
}
}
让不同的数组代表相同的对象并不是一件好事。因此,更好地解决问题的方法是,帖子仅包含一个数组
获取时,您可以执行以下操作:
guard let user = PFUser.current() else { return }
let query = PFQuery(className: "Post")
query.whereKey("username", equalTo: user.username)
query.findObjectsInBackground(block: { (posts, error) in
if let posts = posts {
self.posts = posts
}
})
通过这种方式,当您想在删除功能中将其删除时:
if indexPath.row < self.posts.count {
self.posts[indexPath.row].deleteInBackground()
}