- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了选项卡应用程序崩溃的问题,而且我真的找不到解决方案。当应用程序首次执行并且当我选择第三个选项卡项(天气预报)时,一切正常,表数据正在加载其中的所有数据,并且一切都显示正常,用户可以毫无问题地进行交互。当我选择另一个选项卡项目然后返回天气预报选项卡时,会发生崩溃问题。我担心的是,有时它会崩溃,但有时不会。这是我真正无法理解的,为什么它会连续工作一次甚至几次,有时它会在第一次尝试时崩溃。我想在某个时候当 viewdidAppear 加载时, View 生命周期中,我的数组没有及时填充,因此 TableView 试图访问不存在的数组元素并崩溃。这就是我尝试使用线程和调度队列来管理的内容,但仍然出现问题..
有什么想法吗?非常感谢您的帮助。
有时我会收到此错误消息:
2017-12-09 14:19:11.431048+0100 Le Baluchon[19344:5162393] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Invalid update: invalid number of rows in section 0. The number of rows contained in an existing section after the update (0) must be equal to the number of rows contained in that section before the update (4), plus or minus the number of rows inserted or deleted from that section (0 inserted, 0 deleted) and plus or minus the number of rows moved into or out of that section (0 moved in, 0 moved out)
但很多时候,我会在 VC 的第 73 行旁边看到此错误消息:
Thread 1: Fatal error: Index out of range
有什么想法吗?
这是我的 VIewController:
class WeatherViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
@IBOutlet weak var weatherView: UITableView!
@IBOutlet weak var weatherDataLoading: UIActivityIndicatorView!
let error = Notification.Name(rawValue: "Error")
var selectedRow: Int?
var count: Int = 0
var names = [String]()
var temps = [String]()
var dates = [String]()
var climates = [String]()
var forecastDates = [String]()
var forecastClimates = [String]()
override func viewDidLoad() {
super.viewDidLoad()
self.weatherView.dataSource = self
self.weatherView.delegate = self
NotificationCenter.default.addObserver(self, selector: #selector(displayErrorAlert), name: error, object: nil)
}
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
WeatherRequest.getWeatherCast(completion: { (names, temps, dates, climates, forecastdates, forecastclimates) in
self.names = names
self.temps = temps
self.dates = dates
self.climates = climates
self.forecastDates = forecastdates
self.forecastClimates = forecastclimates
self.weatherView.reloadData()
self.weatherDataLoading.isHidden = true
})
}
@objc func displayErrorAlert() {
let alertVC = UIAlertController(title: "Error", message: "Couldn't retrieve data from servor", preferredStyle: .alert)
alertVC.addAction(UIAlertAction(title: "OK", style: .cancel, handler: nil))
self.present(alertVC, animated: true, completion: nil)
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return names.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "table_cell", for: indexPath) as! WeatherViewCell
cell.separatorInset = UIEdgeInsets.zero
cell.firstStackView.constant = tableView.frame.height / 4
cell.cityName.text = names[indexPath.item]
cell.cityDate.text = dates[indexPath.item]
cell.cityClimate.text = climates[indexPath.item]
cell.cityTemp.text = temps[indexPath.item]
cell.firstForecastedClimate.text = forecastClimates[count]
cell.firstForecastedDate.text = forecastDates[count]
count += 1
cell.secondForecastedClimate.text = forecastClimates[count]
cell.secondForecastedDate.text = forecastDates[count]
count += 1
cell.thirdForecastedClimate.text = forecastClimates[count]
cell.thirdForecastedDate.text = forecastDates[count]
cell.isExpanded = false
count += 8
return cell
}
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
guard let cell = tableView.cellForRow(at: indexPath) as? WeatherViewCell
else { return }
selectedRow = indexPath.item
cell.contentView.backgroundColor = UIColor.darkGray
cell.contentView.alpha = 0.5
cell.isExpanded = !cell.isExpanded
self.weatherView.beginUpdates()
self.weatherView.endUpdates()
}
func tableView(_ tableView: UITableView, didDeselectRowAt indexPath: IndexPath) {
guard let cell = tableView.cellForRow(at: indexPath) as? WeatherViewCell
else { return }
self.weatherView.beginUpdates()
cell.contentView.backgroundColor = nil
cell.contentView.alpha = 1
cell.isExpanded = false
self.weatherView.endUpdates()
}
override func viewDidDisappear(_ animated: Bool) {
super.viewDidDisappear(animated)
guard let selectedRow = selectedRow else { return }
guard let cell = weatherView.cellForRow(at: [0,selectedRow]) as? WeatherViewCell
else { return }
cell.isExpanded = false
weatherView.beginUpdates()
cell.contentView.backgroundColor = nil
cell.contentView.alpha = 1
weatherView.endUpdates()
clear()
}
func clear() {
count = 0
names = [String]()
temps = [String]()
dates = [String]()
climates = [String]()
forecastDates = [String]()
forecastClimates = [String]()
}
}
这是我从 API Yahoo Weather 获取数据的类。
class WeatherRequest {
static func getWeatherCast(completion: @escaping ([String], [String], [String], [String], [String], [String]) -> ()) {
DispatchQueue.global(qos: .userInteractive).async {
var names = [String]()
var temps = [String]()
var dates = [String]()
var climates = [String]()
var forecastDates = [String]()
var forecastClimates = [String]()
let url = URL(string: "https://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20weather.forecast%20where%20woeid%20in%20(select%20woeid%20from%20geo.places(1)%20where%20text%20in(%22Miami%22%2C%20%22new%20york%22%2C%20%22chicago%22%2C%20%22philadelphia%22))%20and%20u%3D'c'&format=json&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys")
let task = URLSession.shared.dataTask(with: url!) { (data, response, error) in
guard let myData = data else { return }
do {
let decoder = JSONDecoder()
decoder.dateDecodingStrategy = .iso8601
let root = try decoder.decode(Root.self, from: myData)
for channel in root.channels {
dates.append(channel.item.condition.date)
temps.append(channel.item.condition.temp + " °C")
climates.append(channel.item.condition.text)
}
for channel in root.channels {
for forecast in channel.item.forecast {
forecastDates.append(forecast.date)
forecastClimates.append(forecast.text)
}
}
names = ["Miami", "New York", "Chicago", "Philadelphia"]
DispatchQueue.main.async {
completion(names, temps, dates, climates, forecastDates, forecastClimates)
}
} catch let fetchError {
print(fetchError)
}
}
task.resume()
}
}
}
最佳答案
该错误清楚地解释了这一点。当调用开始更新和结束更新时,将像这样检查行数。更新后的行数应等于更新前的行数加上或减去添加或删除的行数。在您的情况下,api 返回 4 个值,但当您更改选项卡并返回时,计数更改为 0(此处 api 响应延迟)。因此,在更新 4 之前和更新 0 之后,不会调用删除单元格。有关更多信息,请阅读 beginupdates 的描述,它有明确的记录。
关于ios - UITableView 索引超出范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47729801/
我坚持我的项目(用 Swift 编写) 我有一个 UITableView,它有一个字符串,它提供了表格中的十个类别。我想做的是选择这些类别中的一个来触摸它,然后打开一个包含其他类别的 secondTa
好的,这从 iOS 7 Beta 6 开始就被打破了。 在启动时,我将表格 View 的背景更改为图像(如果我将其设置为颜色,它会做同样的事情)并且表格单元格是白色的...... 当我选择一个单元格时
我有一个包含不同部分的 UITableView,每个单元格上都有一个图像。因为图像是为每个单元格单独下载的,所以我正在寻找一种延迟加载解决方案。 在 iOS Developer Library 上,它
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
可以在UIRefreshControl的底部添加UITableView吗? 我会用它来加载更多数据。 拜托,有什么建议吗? 最佳答案 我相信不会有任何简单的解决方案来解决这个问题。可能有人可以编写一个
我有一个 UITableView 和一个使用 Swift 的自定义 UITableViewCell。当我设置 self.MyTable.editing = true 时,我看到该行上有删除图标,并且似
我为 iPhone 创建了一个下载器应用程序。我有用于显示主动/被动下载的表格 View 。在 tableview 的自定义单元格中有进度条,它显示 %XX 下载状态。现在我正在使用 NSTimer
我正在编写 UITableView 的自定义子类。我需要这个对象本身成为它自己的数据源和委托(delegate),然后这个子类将有它自己的数据源和委托(delegate)。这主要是为了让我可以拦截对数
我有一个问题已经困扰我几天了。 我有一个名为 countries 的数组。该数组包含一个自定义对象,其中包含国家、城市、IP、状态等数据。 我需要在按属性“国家/地区”划分的表格 View 中显示这些
我有一个 UITableViewController,目前显示 4 个将始终显示的单元格,并且想将它们组合在一起,但我不知道如何操作。当在 UIViewController 或类似的东西上插入标准 U
我以编程方式创建了一个 UITableView,现在我想向它添加一个固定的标题。 正如我下面的代码一样,标题也随着我的 tableview 滚动。 UILabel *label = [[[UI
我正在创建一个 UITableViewController(在 UINavigationController 的根部)并在另一个 View Controller 之上以模态方式呈现它。我让它在一定程度
我有问题。我有动态 TableView 。所以我需要在我的 textLabel 中更改文本大小。我试过: 一个: cell.textLabel.font = [UIFont systemFontOfS
iOS 8 中的新功能是 separatorEffect属性,您可以为其分配 UIVisualEffect。有没有人知道这是做什么用的?我试过了,我不认为它有任何,呃,视觉效果。 最佳答案 我想知道完
今天早上,我刚刚安装了包含iOS 6的新Xcode。 我有一个加载了包含章节和行的plist文件的表格 View 。各章定义各节。 用户选择章节和行,并将tableview自动滚动到正确的位置(在vi
我在iOS 7上启动VoiceOver时遇到了一些麻烦。我确实在UITableViewHeaderFooterView中注册了viewDidLoad子类的实例,但是当我用-[tableView deq
我在 UITableView 中添加了一些数据,我想更改单元格中显示的文本的颜色。 是否有委托(delegate)方法可以执行此操作,或者有其他方式吗? 最佳答案 无需标签 您只需要编码: cell.
是否可以在滚动 UITableView 时动态更改单元格的高度? 当用户将其向下拖动到顶部时,滚动位置到达某个点时,我需要更改多个单元格的高度。我可以通过发出 reloadData 成功地做到这一点,
我正在使用 iOS 5,并在表格中动态生成单元格(2 个部分,每个部分 3 行)。每个部分都有一个标题,该标题也是使用 titleForHeaderInSection 调用动态生成的。 我还设置了一个
我正在寻找 UITableView 的回调函数当我使用 Apple Remote 导航并按向上或向下键选择行时(而不是按 Enter 键时),当该行聚焦时。 在 iOS 上,我们有 didSelect
我是一名优秀的程序员,十分优秀!