我遇到了 NSFetchedResultsViewController 的问题。这是我的设置。我的应用程序 rootViewController 是一个 TabBarController。连接到我的 UITabBarController 的是两个 View Controller (所以我有 2 个选项卡)。与每个选项卡关联的 UIViewControllers 都有容器,我在其中嵌入了另一个 UIViewController。这些 UIViewControllers 之一有一个 UITableView,我试图用来自 CoreData 的数据填充它。因此,为了填充 UITableView,我使用了 NSFetchedResultsViewController。
这是我的奇怪问题。如果我将带有 UITableView/NSFetchedResultsController 的 UIViewController 作为第一个选项卡,以便在应用程序加载时首先显示它,一切都很好,我在 tableview 中看到了预期的 3 行数据(我在每个自定义中设置了两个标签表格单元格)。
Labels visible for each row when on first tab
但是,如果我将 ViewController 设置为第二个选项卡,启动应用程序,查看我的第一个选项卡,然后点击我的 tableview 所在的第二个选项卡,将创建 3 行,但我看不到标签,只有一个带有披露指示符的空白行。
Labels disappear, but the rows are still created when on second tab
NSFectchedResultsController 似乎工作正常,因为即使在单元格标签丢失的情况下,但创建了行,我注销了应该显示的值,并打印了值,所以我的 managedobject 具有值.
以前我没有使用 CoreData,只是用内存中的简单对象填充表格,在选项卡之间点击时一切正常……数据总是出现。我在实现 fetchedResultsController 后才开始看到这个问题。
这是我的代码:
class OrderListViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, NSFetchedResultsControllerDelegate {
@IBOutlet weak var searchBar: UISearchBar!
@IBOutlet weak var tableView: UITableView!
var delegate: OrderListViewControllerDelegate?
private lazy var fetchedResultsController: NSFetchedResultsController = {
let request = NSFetchRequest(entityName: "ListOrder")
let dateSort = NSSortDescriptor(key: "statusSubmittedAt", ascending: true)
request.sortDescriptors = [dateSort]
let pred = NSPredicate(format: "(statusBuilt == %@ and statusCancelled == %@ and statusComplete == %@ and statusSubmitted == %@)", NSNumber(bool: false), NSNumber(bool: false), NSNumber(bool: false), NSNumber(bool: true))
request.predicate = pred
let moc = (UIApplication.sharedApplication().delegate as? AppDelegate)!.managedObjectContext
let controller = NSFetchedResultsController(fetchRequest: request, managedObjectContext: moc, sectionNameKeyPath: nil, cacheName: nil)
controller.delegate = self
return controller
}()
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
do {
try fetchedResultsController.performFetch()
} catch {
fatalError("Failed to initialize FetchedResultsController: \(error)")
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
//Dispose of any resources that can be recreated.
}
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return fetchedResultsController.sections!.count
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
let sections = fetchedResultsController.sections! as [NSFetchedResultsSectionInfo]
let sectionInfo = sections[section]
return sectionInfo.numberOfObjects
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = (tableView.dequeueReusableCellWithIdentifier("OrderListTableViewCell", forIndexPath: indexPath) as? OrderListTableViewCell)!
// Configure the cell...
let order = (fetchedResultsController.objectAtIndexPath(indexPath) as? ListOrder)!
// Update Cell
if let userDisplayName = order.userDisplayName {
print(userDisplayName) //prints correct value to console
cell.orderName.text = userDisplayName
}
if let placementDescription = order.tagPlacementDescription {
cell.orderName.text = cell.orderName.text! + " - \(placementDescription)"
print(placementDescription) //prints correct value to console
}
if let orderTime = order.statusSubmittedAt {
cell.orderTime.text = String.stringTimeFromDate(orderTime)
}
return cell
}
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
self.delegate?.didSelectOrder(self, order:(fetchedResultsController.objectAtIndexPath(indexPath) as? ListOrder)!)
}
}
非常感谢任何帮助。我没主意了。
最佳答案
你的代码似乎是正确的,但我宁愿让你按照通常在代码中实现的方式来制作你的 NSFetchResultsController。您需要在委托(delegate)中至少实现三个方法
controllerWillChangeContent:controllerDidChangeContent:controller:DidChangeObject:atIndexPath:forChangeType:newIndexPath希望这对您有所帮助。
P. S. 您确定每次调用单元格方法时都会打印您的值吗?尝试设置断点或 else-clause 去检查这个。此外,我会重新检查电池和 socket 连接的标识符
关于ios - NSFetchedResultsController 返回行并填充表格,但表格单元格标签消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38473716/
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我有一个驼峰式字符串,例如:JustAString。我想按照以下规则形成长度为4的字符串:抓取所有大写字母;如果超过4个大写字母,只保留前4个;如果少于4个大写字母,则将最后大写字母后的字母大写并添加字母,直到长度变为4。以下是可能发生的3种情况:ThisIsMyString将产生TIMS(大写字母);ThisIsOneVeryLongString将产生TIOV(前4个大写字母);MyString将生成MSTR(大写字母+tr大写)。我设法用这个片段解决了前两种情况:str.scan(/[A-Z]/).first(4).join但是,我不太确定如何最好地修改上面的代码片段以处理最后一种
我正在尝试解析一个文本文件,该文件每行包含可变数量的单词和数字,如下所示:foo4.500bar3.001.33foobar如何读取由空格而不是换行符分隔的文件?有什么方法可以设置File("file.txt").foreach方法以使用空格而不是换行符作为分隔符? 最佳答案 接受的答案将slurp文件,这可能是大文本文件的问题。更好的解决方案是IO.foreach.它是惯用的,将按字符流式传输文件:File.foreach(filename,""){|string|putsstring}包含“thisisanexample”结果的
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"
我正在尝试用Prawn生成PDF。在我的PDF模板中,我有带单元格的表格。在其中一个单元格中,我有一个电子邮件地址:cell_email=pdf.make_cell(:content=>booking.user_email,:border_width=>0)我想让电子邮件链接到“mailto”链接。我知道我可以这样链接:pdf.formatted_text([{:text=>booking.user_email,:link=>"mailto:#{booking.user_email}"}])但是将这两行组合起来(将格式化文本作为内容)不起作用:cell_email=pdf.make_c