UITableView

初始化

lazy var tbvData: UITableView = {
        
        let tableView = UITableView.init(frame: .zero, style: .plain)
        tableView.delegate = self
        tableView.dataSource = self
        tableView.backgroundColor = UIColor.MJTheme.bg
        tableView.rowHeight = 70
        tableView.estimatedSectionHeaderHeight = 0;
        tableView.estimatedSectionFooterHeight = 0;
        tableView.tableFooterView = UIView.init(frame: .zero);

        let cell = UINib.init(nibName: "KSimpleTitleTbvCell", bundle: nil)
        tableView.register(cell, forCellReuseIdentifier: "KSimpleTitleTbvCell")
        return tableView
    }()

self.view.addSubview(tbvData)
        tbvData.snp.makeConstraints { (make) -> Void in
            make.edges.equalTo(self.view)
        }

自定义cell,分区头部,尾部

---IB cell
let cell = UINib.init(nibName: "KSimpleTitleTbvCell", bundle: nil)
tableView.register(cell, forCellReuseIdentifier: "KSimpleTitleTbvCell")
let sectionHead = UINib.init(nibName: "WorkHomeTbvSectionHeadView", bundle: nil)
tableView.register(sectionHead, forHeaderFooterViewReuseIdentifier: "WorkHomeTbvSectionHeadView")
---class cell
tableView.register(MJTableViewCell.self, forCellReuseIdentifier: "MJTableViewCell")
tableView.register(MJSectionHeadView.self, forHeaderFooterViewReuseIdentifier: "MJSectionHeadView")
tableView.register(MJSectionFootView.self, forHeaderFooterViewReuseIdentifier: "MJSectionFootView")


 let cell = MJTableViewCell(style: .subtitle, reuseIdentifier: "MainClassicalCell")
    

表头,表尾

   lazy var tbvHeadView: WorkHomeTbvHeadView = {
        let tableHeadView = Bundle.main.loadNibNamed("WorkHomeTbvHeadView", owner: self, options: nil)?.last as! WorkHomeTbvHeadView
        tableHeadView.frame = CGRect(x: 0, y: 0, width: kSCREEN_WIDTH, height: 100)
        tableHeadView.autoresizingMask = UIViewAutoresizing(rawValue: 0)

        return tableHeadView
    }()
  lazy var tbvFootView: WorkHomeTbvHeadView = {
        let tableFootView = Bundle.main.loadNibNamed("WorkHomeTbvHeadView", owner: self, options: nil)?.last as! WorkHomeTbvHeadView
        tableFootView.frame = CGRect(x: 0, y: 0, width: kSCREEN_WIDTH, height: 100)
        tableFootView.autoresizingMask = UIViewAutoresizing(rawValue: 0)
        
        return tableFootView
    }()

        tableView.tableHeaderView = self.tbvHeadView
        tableView.tableFooterView = self.tbvFootView

常用代理方法

   extension NewHomeVC: UITableViewDelegate, UITableViewDataSource {
    
    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return dataArray.count
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        
        let cell = tableView.dequeueReusableCell( withIdentifier: "KSimpleTitleTbvCell", for: indexPath) as! KSimpleTitleTbvCell
        cell.labTitle.text = dataArray[indexPath.row]
        
        return cell
    }
    
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        print(indexPath.row)
    }
    
}

分区头部,尾部

    /*分区头部部高度*/
    func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
        return 50
    }
    
    func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
        
        let sectionHead = tableView.dequeueReusableHeaderFooterView(withIdentifier: "WorkHomeTbvSectionHeadView") as! WorkHomeTbvSectionHeadView
        sectionHead.labTitle.text = "华南名医联盟"
        return sectionHead
        
    }
    
    /*分区尾部高度*/
    func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat {
        return 50
    }
    
    func tableView(_ tableView: UITableView, viewForFooterInSection section: Int) -> UIView? {
        
         let sectionFoot = tableView.dequeueReusableHeaderFooterView(withIdentifier: "WorkHomeTbvSectionHeadView") as! WorkHomeTbvSectionHeadView
        sectionFoot.labTitle.text = "华南名医联盟"
        return sectionFoot
    }

UITableView 方法,特性

`默认选中第一行`
let path = IndexPath(item: 0, section: 0)
tableView(tbvData, didSelectRowAt: path)
`一句话去除UITableView底部多余行及分割线`
tableView.tableFooterView = UIView(frame: CGRect.zero)
`取消分割线`
tableView.separatorStyle = .none
`分割线颜色`
tableView.separatorColor = UIColor.red
`右边尖括号`
cell.accessoryType = .disclosureIndicator
`去掉点击效果`
cell.selectionStyle = .none
`一个section刷新`
let indexSet = NSIndexSet(index: 2)
tbvData.reloadSections(indexSet as IndexSet, with: .automatic)
`一个cell刷新`
let indexPath = IndexPath(row: 3, section: 0)
tbvData.reloadRows(at: [indexPath], with: .none)
`滚动到指定位置 `
var dayOne = IndexPath(row: 0, section: 2)
tbvData.scrollToRow(at: dayOne, at: .top, animated: true)
`滚动到顶部`
tableView.setContentOffset(CGPoint(x: 0, y: 0), animated: false)
`cell 左右空隙`
override var frame: CGRect{
        didSet{
            var f: CGRect = frame
            f.origin.x = kTbvSpace
            f.size.width = frame.size.width - kTbvSpace * 2
            super.frame = f
        }
    }
`iOS 11 设配  滑动卡顿(漂移和抽疯的现象)3句不少 重要`
tableView.estimatedRowHeight = 0
tableView.estimatedSectionHeaderHeight = 0
tableView.estimatedSectionFooterHeight = 0
`点击松开灰色取消`
tableView.deselectRow(at: indexPath, animated: true)
`取消向下偏移 64/20`
if #available(iOS 11.0, *) {
            srvData.contentInsetAdjustmentBehavior = .never
        } else {
            automaticallyAdjustsScrollViewInsets = false
        }
`禁止滑动`
tableView.isScrollEnabled = false
`分割线边距`
tableView.separatorInset = UIEdgeInsets(top: 0, left: 17, bottom: 0, right: 0)
`注意cell 约束的内边距`
tableView.contentInset = UIEdgeInsets(top: 0, left: 0, bottom: 8, right: 0)
`sectionView 有默认颜色,xib 不修改他的 颜色,添加一个view`
let sectionHead = UIView.init()
sectionHead.backgroundColor = tableView.backgroundColor
return sectionHead
`点击颜色修改`
cell.selectedBackgroundView = UIView(frame: cell.frame)
cell.selectedBackgroundView?.backgroundColor = kBgColor
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容