- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 KVO 来跟踪对我的帐户对象的属性的更改,其中的重要部分如下所示:
class Account: NSObject {
var battleTagLabel: String!
dynamic var onlineStatusIcon: String!
dynamic var currentGameIcon: String!
dynamic var currentStatusLabel: String!
当这三个属性的值发生变化时,我希望在我的 tableview 单元格中收到通知。我的表格 View 单元格类:
import Foundation
import UIKit
private var observerContext = 0
class FriendAccountCell: UITableViewCell {
@IBOutlet weak var onlineStatusIcon: UIImageView!
@IBOutlet weak var battleTag: UILabel!
@IBOutlet weak var currentGameIcon: UIImageView!
@IBOutlet weak var currentStatusLabel: UILabel!
weak var tableView: UITableView!
weak var delegate: CustomCellDelegate?
var onlineStatusIconFlag = false
var currentStatusLabelFlag = false
var currentGameIconFlag = false
var account: Account? {
willSet {
if onlineStatusIconFlag {
print("onlineStatusIconFlag: \(onlineStatusIconFlag)")
if newValue?.onlineStatusIcon != account?.onlineStatusIcon && account?.onlineStatusIcon != nil {
self.account?.removeObserver(self, forKeyPath: #keyPath(onlineStatusIcon))
onlineStatusIconFlag = false
}
}
if currentStatusLabelFlag {
if newValue?.currentStatusLabel != account?.currentStatusLabel && account?.currentStatusLabel != nil {
account?.removeObserver(self, forKeyPath: #keyPath(currentStatusLabel))
currentStatusLabelFlag = false
}
}
if currentGameIconFlag {
if newValue?.currentGameIcon != account?.currentGameIcon && account?.currentGameIcon != nil {
account?.removeObserver(self, forKeyPath: #keyPath(currentGameIcon))
currentGameIconFlag = false
}
}
}
didSet {
if oldValue?.onlineStatusIcon != account?.onlineStatusIcon {
if account?.onlineStatusIcon == "onine" {
self.onlineStatusIcon.image = UIImage(named: "20pxButtonGreen")
} else if account?.onlineStatusIcon == "idle" {
self.onlineStatusIcon.image = UIImage(named: "20pxButtonYellow")
} else if account?.onlineStatusIcon == "busy" {
self.onlineStatusIcon.image = UIImage(named: "20pxButtonRed")
} else {
self.onlineStatusIcon.image = UIImage(named: "20pxButtonBlack")
}
account?.addObserver(self, forKeyPath: #keyPath(onlineStatusIcon), context: &observerContext)
onlineStatusIconFlag = true
}
if oldValue?.currentStatusLabel != account?.currentStatusLabel {
self.currentStatusLabel?.text = account?.currentStatusLabel
account?.addObserver(self, forKeyPath: #keyPath(currentStatusLabel), context: &observerContext)
currentStatusLabelFlag = true
}
if oldValue?.currentGameIcon != account?.currentGameIcon {
if let currentGame = account?.currentGameIcon {
switch currentGame {
case "overwatch":
self.currentGameIcon.image = UIImage(named: "logo-ow")
case "hearthstone":
self.currentGameIcon.image = UIImage(named: "logo-hs")
case "worldOfWarcraft":
self.currentGameIcon.image = UIImage(named: "logo-wow")
case "diablo3":
self.currentGameIcon.image = UIImage(named: "logo-d3")
case "heroesOfTheStorm":
self.currentGameIcon.image = UIImage(named: "logo-heroes")
case "starCraft":
self.currentGameIcon.image = UIImage(named: "logo-sc")
case "starCraft2":
self.currentGameIcon.image = UIImage(named: "logo-sc2")
case "":
self.currentGameIcon.image = nil
default:
self.currentGameIcon.image = nil
}
}
account?.addObserver(self, forKeyPath: #keyPath(currentGameIcon), context: &observerContext)
currentGameIconFlag = true
}
}
}
override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {
guard context == &observerContext else {
super.observeValue(forKeyPath: keyPath, of: object, change: change, context: context)
return
}
delegate?.didUpdateObject(cell: self)
}
deinit {
print("deinit called")
if onlineStatusIconFlag {
account?.removeObserver(self, forKeyPath: #keyPath(onlineStatusIcon))
onlineStatusIconFlag = false
}
if currentStatusLabelFlag {
account?.removeObserver(self, forKeyPath: #keyPath(currentStatusLabel))
currentStatusLabelFlag = false
}
if currentGameIconFlag {
account?.removeObserver(self, forKeyPath: #keyPath(currentGameIcon))
currentGameIconFlag = false
}
}
这是我的 tableview 类的相关部分:
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let identifier: String = "FriendAccountCell"
var cell: FriendAccountCell
if let friendCell = self.tableView.dequeueReusableCell(withIdentifier: identifier){
cell = friendCell as! FriendAccountCell
} else {
cell = FriendAccountCell(style: .default, reuseIdentifier: identifier)
cell.selectionStyle = .none
}
var filteredFriends = orderFriends(friendsArray: Array(MyAccountInfo.allFriends.values))
cell.delegate = self
cell.account = filteredFriends[indexPath.row]
cell.battleTag.text = filteredFriends[indexPath.row].battleTagLabel
cell.currentStatusLabel.text = filteredFriends[indexPath.row].currentStatusLabel
return cell
}
(上面没有粘贴,但我也在我的tableview类中实现了委托(delegate)函数来重新加载特定的单元格。)
当应用程序首次加载并且所有最新数据都从服务器获取时,这些特定属性的更改会很快发生。之后,变化会更加稳定和缓慢地发生。
尽管我尝试使用标志和其他策略来正确跟踪观察者的添加和删除,但我仍然收到“无法删除关键路径的观察者,因为它未注册为观察者”错误。
最佳答案
我建议简化添加/删除观察者逻辑。当前的代码太复杂,提供的路径太多,您可能会错过一条或另一条。所以,只需在 willSet
中删除观察者,并在 didSet
中添加观察者:
var account: Account? {
willSet {
account?.removeObserver(self, forKeyPath: #keyPath(Account.onlineStatusIcon))
account?.removeObserver(self, forKeyPath: #keyPath(Account.currentStatusLabel))
account?.removeObserver(self, forKeyPath: #keyPath(Account.currentGameIcon))
}
didSet {
account?.addObserver(self, forKeyPath: #keyPath(Account.onlineStatusIcon), context: &observerContext)
account?.addObserver(self, forKeyPath: #keyPath(Account.currentStatusLabel), context: &observerContext)
account?.addObserver(self, forKeyPath: #keyPath(Account.currentGameIcon), context: &observerContext)
// do any additional logic here you want here
}
}
deinit {
account?.removeObserver(self, forKeyPath: #keyPath(Account.onlineStatusIcon))
account?.removeObserver(self, forKeyPath: #keyPath(Account.currentStatusLabel))
account?.removeObserver(self, forKeyPath: #keyPath(Account.currentGameIcon))
}
此外,如果您在 init
中设置了 account
,请记住 willSet
不会被调用,因此您必须手动添加在这种情况下,观察者自己。
关于ios - 在 tableview 单元格中使用 KVO 跟踪对 Swift 3 中类实例的特定属性的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45805868/
我正在对 tableView 是否呈现单元格进行单元测试。 我发现 tableView.cellForRow(at:) 返回 nil,而 tableView.dataSource?tableView(
我有 Tableview 用于显示客户下的食品订单。其中包含水平 UIStackview。在 UIStackView UIStackview 中很少有一/两行标签和一个用于显示订单项的UITableV
我有 Viewcontroller,我在其中设置了 ScrollView 。在 scrollview 中,我有一个 tableview,它位于 Container 中,就在容器下方,当我将 table
我想在滚动时让我的第一个单元格始终位于 tableview 的顶部。 任何帮助都是可观的。提前致谢... 最佳答案 这是为 UITableView 创建标题 View 的方法 - (UIView *)
在我的应用程序中,我点击一行,它会在其下方展开另一行。我想生成一种随机颜色,当我单击一行时,行背景会变成该颜色,而它下面的展开行会变成相同的颜色。如何让行生成相同的随机颜色? 我创建了一个函数来生成随
我正在为这个问题苦苦挣扎,所以我需要你的帮助。基本上我已经编写了一个复杂的 TableView Controller (使用 NSFetchedResults 协议(protocol)等)并且已经在我
我正在使用 JavaFx 2.2。我遇到了一个问题,我无法在 TableView 列中放置不同的组件。例如我有两列 1) 回答 2) 答案类型 如果 AnswerType 包含“Multiple Ch
试图弄清楚如何在 javafx 2 中禁用表列的重新排序? 最佳答案 这是解决方案: tblView.getColumns().addListener(new ListChangeListener()
我一直在寻找有关将数据刷新到 tableview 的信息。我试图直接修改模型,但我遇到了一个错误。我修改了模型,但表格没有刷新,只有当我移动一列时,表格才会显示修改后的值。 为了给你展示一个例子(13
给定一个TableView,我需要检测单元格上的双击。 tableView.setOnMouseClicked(new EventHandler() { @Override publi
我成功创建了一个 TableView,其中将特定列分配给了数据模型类。该程序可以将 csv 文件解析为其中并在表中正确显示所有内容。在此阶段,滚动不是问题。 然后我想选择特定行并将它们发送到另一个表。
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我有一个通过 Tableview 显示玩家的应用程序。用户可以“添加”一个新玩家并输入他的姓名、高度、体重、图片等...保存后将被添加到 Tableview 中。他们还可以点击每个玩家,然后将他们带到
对于大学,我必须编写一个小应用程序,其想法是创建一个小公式集合。这个概念是有一个类别列表,选择类别后您会收到一个公式列表。选择所需的公式后,您将看到公式计算器的 View 。 我正在努力获得第一个UI
如果我只加载一个 TableView ,我的 View 中必须有两个 TableView ,它工作正常。但是当我尝试使用下面的方法加载两个表格 View 时,它给出了以下异常。 未捕获异常“NSRan
我是 JavaFx 的新手,我正在尝试创建一个 TableView ,而 fxml 是使用场景生成器创建的。如果我运行该程序,该表不会获取值。我发现这个问题在某种程度上符合我的要求( javaFX 2
是否可以对 tableView 进行反向排序?我搜索了很多解决方案,但没有任何效果。 效果就像whatsapp聊天。 一个普通的tableView是: ---------- label 1 -----
我有一个有趣的问题。我有两个 TableView ,一个在另一个里面。我有一个结构,我想用它来将数据添加到我的 TableView 中。该结构有 2 个字符串项和另一个具有 3 个字符串项的结构的数组
我正在使用的方法 func tableView(tableView: UITableView, editActionsForRowAtIndexPath indexPath: NSIndexPath
我是一名优秀的程序员,十分优秀!