上一篇开始用Swift开发iOS 10 - 8 Table View和UIAlertController的交互是Table Row选择的操作,这一篇继续上一篇的代码实现删除操作。
滑动删除
- 实现
UITableViewDataSource
中相应方法:
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
}
此时滑动有删除按钮:
- 删除数据
override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
restaurantNames.remove(at: indexPath.row)
restaurantLocations.remove(at: indexPath.row)
restaurantTypes.remove(at: indexPath.row)
restaurantIsVisited.remove(at: indexPath.row)
restaurantImages.remove(at: indexPath.row)
}
}
UITableViewCellEditingStyle
有两种insert
和delete
。
运行后发现删除动作后,相应的table view row被没有消失,因为上面的删除只是删除了相应数组中的数据,并没有在视图上显示,如要重新加载才会删除。
重新加载UITableView
在tableView(_:commit:forRowAt:)
后添加:
tableView.reloadData()
另外,更好的刷新table view的方法是使用UITableView
的deleteRows(at:with:)
方法,还有动画效果:
tableView.deleteRows(at: [indexPath], with: .fade)
用UITableViewRowAction为滑动产生更多动作
override func tableView(_ tableView: UITableView, editActionsForRowAt indexPath: IndexPath) -> [UITableViewRowAction]? {
// 1
let shareAction = UITableViewRowAction(style: .default, title: "Share", handler: {
(action, indexPath) -> Void in
// 3
let defaultText = "Just checking in at " + self.restaurantNames[indexPath.row]
let activityController = UIActivityViewController(activityItems: [defaultText], applicationActivities: nil)
self.present(activityController, animated: true, completion: nil)
})
// 1
let deleteAction = UITableViewRowAction(style: .default, title: "Delete", handler: {
(action, indexPath) -> Void in
self.restaurantNames.remove(at: indexPath.row)
self.restaurantLocations.remove(at: indexPath.row)
self.restaurantTypes.remove(at: indexPath.row)
self.restaurantIsVisited.remove(at: indexPath.row)
self.restaurantImages.remove(at: indexPath.row)
})
// 2
return [deleteAction, shareAction]
}
- 1
UITableViewRowAction
的用法和UIAlertAction
类似。style相同,具体功能是在回调闭包中实现的。 -
UIActivityViewController
继承是UIViewController
,提供一些服务,例如拷贝到剪贴板,分享内容到社交媒体,通过Messages发送项目等。
- 一旦实现了
tableView(_:editActionsForRowAt:)
方法,tableView(_:commit:forRowAt:)
方法产生delete按钮将不再产生,所以要在tableView(_:commit:forRowAt:)
中添加delete按钮。 - 2 返回的
UITableViewRowAction
的数组,action的显示顺序是,按照数组的顺序在屏幕从有到左显示。 - 3
defaultText
是分享的内容,不仅可以是文本,也可以添加图片对象UIImage
。此处代码修改一下:
let defaultText = "Just checking in at " + self.restaurantNames[indexPath.row]
if let imageToShare = UIImage(named: self.restaurantImages[indexPath.row]) {
let activityController = UIActivityViewController(activityItems: [defaultText, imageToShare], applicationActivities: nil)
self.present(activityController, animated: true, completion: nil)
}
定制UITableViewRowAction
可以修改背景颜色:
shareAction.backgroundColor = UIColor(red: 48.0/255.0, green: 173.0/255.0,
blue: 99.0/255.0, alpha: 1.0)
deleteAction.backgroundColor = UIColor(red: 202.0/255.0, green: 202.0/255.0,
blue: 203.0/255.0, alpha: 1.0)
代码
Beginning-iOS-Programming-with-Swift
说明
此文是学习appcode网站出的一本书 《Beginning iOS 10 Programming with Swift》 的一篇记录
系列文章目录
- 开始用Swift开发iOS 10 - 1 前言
- 开始用Swift开发iOS 10 - 2 Hello World!第一个Swift APP
- 开始用Swift开发iOS 10 - 3 介绍Auto Layout
- 开始用Swift开发iOS 10 - 4 用Stack View设计UI
- [开始用Swift开发iOS 10 - 5 原型的介绍]
- 开始用Swift开发iOS 10 - 6 创建简单的Table Based App
- 开始用Swift开发iOS 10 - 7 定制Table Views
- 开始用Swift开发iOS 10 - 8 Table View和UIAlertController的交互
- 开始用Swift开发iOS 10 - 9 Table Row的删除, UITableViewRowAction和UIActivityViewController的使用