- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
每当我一次又一次地按赞和心形按钮时,应用程序就会崩溃并显示“ fatal error :索引超出范围”。
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) - > Int {
return activityArray.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) - > UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "activityCell") as!StreamActivityTableViewCell
cell.likeButton.tag = indexPath.row
print("....\(cell.likeButton.tag)")
cell.heartButton.tag = indexPath.row
cell.likeButton.addTarget(self, action: #selector(liked(sender: )),
for: .touchUpInside)
cell.heartButton.addTarget(self, action: #selector(loved(sender: )),
for: .touchUpInside)
return cell
}
@objc func liked(sender: UIButton) {
let likebutton = sender.tag
print("---- \(likebutton) ... \(sender.tag)")
let headers = ["Authorization": "Bearer \(UserDefaults.standard.string(forKey: "
token ")!)"
]
let parameters: Parameters = [
"activity_id": activityArray[sender.tag].id!
]
print(parameters)
Alamofire.request(Constants.likedURL, method: .post, parameters: parameters, encoding: URLEncoding.default, headers: headers).validate().responseString {
response in
switch (response.result) {
case.success(_):
if (response.result.isSuccess) {
self.activityArray.removeAll()
self.activityShown()
}
case.failure(_):
print("Error message:\(response.error!.localizedDescription)")
let alert = UIAlertController(title: "Sorry", message: "\(response.error!.localizedDescription)", preferredStyle: UIAlertController.Style.alert)
alert.addAction(UIAlertAction(title: "OK", style: UIAlertAction.Style.default, handler: nil))
self.present(alert, animated: true, completion: nil)
break
}
}
}
func activityShown(){
SVProgressHUD.show()
let headers = ["Authorization":"Bearer \(UserDefaults.standard.string(forKey: "token")!)"]
Alamofire.request(Constants.activitiesURL,method: .get, encoding: JSONEncoding.default, headers: headers).responseJSON { response in
if response.result.isSuccess {
let ActivityJSON : JSON = JSON(response.result.value!)
let activityData = ActivityJSON["data"].arrayValue
let commentData = ActivityJSON["data"].arrayValue
for value in activityData {
let activity = Activity()
activity.name = value["name"].stringValue
activity.content = value["content"].stringValue
activity.published = value["published"].stringValue
activity.thumbnail = value["users"]["photo_thumb"].stringValue
activity.likesCount = value["likes_count"].intValue
activity.liked = value["liked"].intValue
activity.heartCount = value["heart_count"].intValue
activity.hearted = value["hearted"].intValue
activity.commentsCount = value["comments_count"].intValue
activity.commented = value["commented"].intValue
activity.id = value["id"].intValue
activity.currentID = value["users"]["user_id"].intValue
self.activityArray.append(activity)
SVProgressHUD.dismiss()
}
self.tableView.reloadData()
self.refreshControl.endRefreshing()
}
else {
print("Error \(String(describing: response.result.error))")
}
}
}
在这里,我使用 Observer,从 sender.tag 中获取 index.row,当我点击喜欢或心脏按钮时,该 API 会点击并给出响应。当我点击的次数超过 App 崩溃时。
最佳答案
为什么要在成功时执行此操作?
self.activityArray.removeAll()
下次调用这个函数时,索引到数组中
"activity_id": activityArray[sender.tag].id!
但根据您显示的代码,它将为空
如果 activityArray
正在改变并且看起来它被用于表格行,您需要调用 tableView.reloadData()
来清空表格
编辑——在看到更新后的代码之后。
你有一些问题
所以,
liked(sender:)
中的 self.activityArray.removeAll()
行if response.result.isSuccess {
let ActivityJSON : JSON = JSON(response.result.value!)
//// HERE is where we know we are replacing the data
self.activityArray.removeAll()
let activityData = ActivityJSON["data"].arrayValue
let commentData = ActivityJSON["data"].arrayValue
最后
self.tableView.reloadData()
self.refreshControl.endRefreshing()
这段代码需要这样
DispatchQueue.main.async {
self.tableView.reloadData()
self.refreshControl.endRefreshing()
}
因为网络调用可能不会在主线程上完成,但所有 UI 代码都需要在主线程上。
编辑:正如 Claus 在他们的评论中提到的,更好的方法可能是使用 deleteRows/insertRows 和 performBatchUpdates
我建议您首先使用 reloadData() 进行所有操作——然后去阅读苹果文档中的 https://developer.apple.com/documentation/uikit/uitableview/1614960-deleterows和 https://developer.apple.com/documentation/uikit/uitableview/1614879-insertrows和 https://developer.apple.com/documentation/uikit/uitableview/2887515-performbatchupdates也许观看本教程:https://www.youtube.com/watch?v=MC4mDQ7UqEE
如果你这样做——尤其是当你没有重新加载整个表格时——iOS 将做更少的工作并制作更好的默认动画。
关于ios - fatal error : Index out of range, 由于反复按赞和心形按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56615338/
我创建了以下 sub 来简单地说明问题。我将事件工作表的范围 A2:E10 分配给范围变量。然后,对于另一个范围变量,我将这个范围的子范围,单元格 (1, 1) 分配给 (3, 3)。 我原以为这将包
我使用正则表达式来搜索以下属性返回的纯文本: namespace Microsoft.Office.Interop.Word { public class Range {
我正在开发一个宏来突出显示某些行/单元格以供进一步审查。一些值/空白将以红色突出显示,其他以橙色突出显示,而整行应为黄色。我从上一个问题中得到了一些帮助,并添加了更多细节,它工作得几乎完美,但我被困在
这个问题在这里已经有了答案: What is the difference between range and xrange functions in Python 2.X? (28 个答案) 关闭
我在尝试运行脚本时遇到这个奇怪的错误,代码似乎是正确的,但似乎 python (3) 不喜欢这部分: def function(x): if int
我正在编写一种算法,将一些数据写入提供的输出范围(问题的初始文本包括具体细节,这将评论中的讨论转向了错误的方向)。我希望它在 API 中尽可能接近标准库中的其他范围算法。 我查看了 std::rang
这按预期工作: #include #include int main() { auto chunklist = ranges::views::ints(1, 13) | ranges::vie
我这里有一个字符串,我正在尝试对其进行子字符串化。 let desc = "Hello world. Hello World." var stringRange = 1..' 的值转换为预期的参数类型
我有一个高级搜索功能,可以根据日期和时间查询记录。我想返回日期时间范围内的所有记录,然后从该范围内返回我想将结果缩小到一个小时范围(例如 2012 年 5 月 1 日 - 2012 年 5 月 7 日
Go 中的 range 函数和 range 关键字有什么区别? func main(){ s := []int{10, 20, 30, 40, 50, 60, 70, 80, 90}
如果我有一个范围,如何将其拆分为一系列连续的子范围,其中指定了子范围(存储桶)的数量?如果没有足够的元素,则应省略空桶。 例如: splitRange(1 to 6, 3) == Seq(Range(
我正在开发 VSTO Excel 项目,但在管理 Range 对象时遇到一些问题。 实际上,我需要知道当前选定的范围是否与我存储在列表中的另一个范围重叠。所以基本上,我有 2 个 Range 实例,我
在即将推出的 C++20 系列中,将有 range concept具有以下定义: template concept range = __RangeImpl; // exposition-only de
希望有人能回答我的问题。我在 VHDL 代码中遇到了这个命令,但不确定它到底做了什么。有人可以澄清以下内容吗? if ( element1 = (element1'range => '0')) the
可以将范围嵌套在范围中吗?使用范围内的变量?因为我想取得一些效果。为了说明这个问题,我有以下伪代码: for i in range(str(2**i) for i in range(1,2)):
我想在 2 个日期之间创建一个范围,并且我的范围字段有时间 damage_list = Damage.objects.filter(entry_date__range=(fdate, tdate))
在下面的代码中 #include #include #include int main() { std::unordered_mapm; m["1"]=1; m["2"]=2
我试图为我的电子表格做一个简单的循环,它循环遍历一个范围并检查该行是否为空,如果不是,则循环遍历一系列列并检查它们是否为空,如果是则它设置一个消息。 问题是每次它通过循环 ro.value 和 col
我在将一个工作簿范围中的值分配给当前工作簿中的某个范围时遇到问题。当我使用 Range("A1:C1") 分配我的范围时,此代码工作正常,但是当我使用 Range(Cells(1,1),Cells(1
我改写了原来的问题。 Sub s() Dim r As Range Set r = ActiveSheet.Range("B2:D5") Debug.Print r.Rows.Count
我是一名优秀的程序员,十分优秀!