Swift TableView 简单实现冻结窗格功能
2016-11-23 13:23
483 查看
隔了许久,终于摸上了Swift这班车。今天做了一个简例,用tableView实现excel冻结窗格功能 Demo:https://git.oschina.net/sunflowrs/FreezePanes.git
初始化Tableview 实现代理
声明变量时,数组和字典,最好设置成已知类型,避免惹麻烦
改写父类方法时要用override关键字
需要注意:避免爆红 , 一定要实现一下两种方法
初始化Tableview 实现代理
class BasicTableView:UITableView,UITableViewDelegate,UITableViewDataSource
声明变量时,数组和字典,最好设置成已知类型,避免惹麻烦
var titleArr:Array<String> = [] var listArr:Array<Dictionary<String,String>> = []
改写父类方法时要用override关键字
override func awakeFromNib() { super.awakeFromNib() self.delegate = self self.dataSource = self self.separatorStyle = UITableViewCellSeparatorStyle.none self.showsVerticalScrollIndicator = false }
需要注意:避免爆红 , 一定要实现一下两种方法
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return titleArr.count } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { var identifierStr :String if tableView.tag == 1001 { identifierStr = "tableViewCell" }else{ identifierStr = "tableViewCell2" } var cell:UITableViewCell = UITableViewCell.init() if cell.isEqual(nil){ cell = UITableViewCell.init(style: UITableViewCellStyle.default, reuseIdentifier: identifierStr) } if indexPath.row%2 == 0{ cell.backgroundColor = #colorLiteral(red: 1.0, green: 1.0, blue: 1.0, alpha: 1.0) }else{ cell.backgroundColor = #colorLiteral(red: 0.8039215803, green: 0.8039215803, blue: 0.8039215803, alpha: 1) } if tableView.tag == 1001 { cell.textLabel!.text = String(describing: titleArr[ indexPath.row]) cell.textLabel?.textAlignment = NSTextAlignment.center cell.textLabel?.font = UIFont.boldSystemFont(ofSize: 14) if indexPath.row == 0 { cell.textLabel?.textColor = UIColor (colorLiteralRed: 16/255.0, green: 86/255.0, blue: 186/255.0, alpha: 1.0) }else{ cell.textLabel?.textColor = #colorLiteral(red: 0, green: 0, blue: 0, alpha: 1) } }else{ for (idx,value) in listArr.enumerated() { let label:UILabel = UILabel.init(frame: CGRect(x:idx*60,y:0,width:60,height: Int(cell.frame.size.height))) label.textAlignment = NSTextAlignment.center label.font = UIFont.boldSystemFont(ofSize: 14.0) if indexPath.row == 0 { label.textColor = UIColor (colorLiteralRed: 16/255.0, green: 86/255.0, blue: 186/255.0, alpha: 1.0) }else{ label.textColor = #colorLiteral(red: 0, green: 0, blue: 0, alpha: 1) } cell.contentView .addSubview(label) if idx == listArr.count-1{ cell.frame = CGRect(x:cell.frame.origin.x,y:cell.frame.origin.y,width:label.frame.origin.x+label.frame.size.width,height:cell.frame.size.height) } switch (indexPath.row) { case 0: label.text = value["date"]! + "日" case 1: label.text = value["total"] case 2: label.text = value["projectCount"] case 3: label.text = value["visitrate"] case 4: label.text = value["abandonCount"] case 5: label.text = value["abandonrate"] default: label.text = "" } } } return cell; }
相关文章推荐
- Swift TableView实现冻结窗格功能
- Swift - tableView的单元格多选功能的实现(获取多选值、多选删除)
- iOS tableview 实现简单的搜索功能
- IOS 实现3D Touch在tableView的简单应用(swift版)
- iOS tableview 实现简单的搜索功能
- iOS tableview 实现简单的搜索功能
- ios 简单实现tableView单选和多选功能
- iOS UISearchController TableView 实现简单搜索功能
- iOS tableview实现简单搜索功能
- [iOS/Swift]简单实现跟系统一样的毛玻璃效果的View,可在上面加控件,可移动
- 仿QQ好友 TableView 点击展开 收缩功能实现
- [iOS]UIScrollView 与 UIPageControl实现简单相册功能
- 10.5 UIScrollview概念和用法:实现简单的相册功能
- table中的标题行冻结的简单实现
- 应用第三方库EGORefreshTableHeaderView实现下拉刷新功能
- swift tableview中添加侧滑删除功能 类似qq删除
- iOS TableView实现单选checkmark功能
- iOS table简单实现增加移动和删除功能与自定义cell的实现
- UIScrollView -------- 实现简单的相册功能