欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS中TableView如何統(tǒng)一數(shù)據(jù)源代理詳解

 更新時間:2018年07月13日 11:01:26   作者:cdcyd  
這篇文章主要給大家介紹了關(guān)于iOS中TableView如何統(tǒng)一數(shù)據(jù)源代理的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧

前言

TableView 是 iOS 應用程序中非常通用的組件,幾乎每一個界面都有一個TableView,而我們許多的代碼都和TableView有關(guān)系,比如數(shù)據(jù)展示、更新TableView,一些響應選擇事件等,而這些大多都會通過其代理函數(shù)來實現(xiàn),所以在VC中我們通常需要實現(xiàn)大量TableView的代理函數(shù),如下面這樣

func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
 return 12.0
}
func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat {
 return 0.01
}
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
 return 44.0
}
func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
 return nil
}
func tableView(_ tableView: UITableView, viewForFooterInSection section: Int) -> UIView? {
 return nil
}
func numberOfSections(in tableView: UITableView) -> Int {
 return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
 return 10
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
 return UITableViewCell()
}
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
 tableView.deselectRow(at: indexPath, animated: true)
}

如果上面的代碼在每個VC中都實現(xiàn)一次,不僅寫了很多的重復的代碼,還增加了VC的復雜度,所以我在想能不能有一個統(tǒng)一的代理類,我們的TableView只要遵循它,就不用每次都要寫一大堆的代理方法,下面就是我寫的一個代理類的使用

示例代碼

 private var delegate = CCDataSource()

 lazy private var tableView: UITableView = {
  let table = UITableView(frame: self.view.bounds, style: .grouped)
  // 1.注冊cell
  table.register(Custom1Cell.self, forCellReuseIdentifier: "cell1")
  table.register(Custom2Cell.self, forCellReuseIdentifier: "cell2")
  // 2.代理
  table.delegate = self.delegate
  table.dataSource = self.delegate
  return table
 }()

 override func viewDidLoad() {
  super.viewDidLoad()
  self.view.addSubview(tableView)
  self.setupTableView()
  self.loadData()
 }

 private func loadData() {
  // 3.網(wǎng)絡請求數(shù)據(jù)源,并賦值
  delegate.datas = [[Model1(),Model1(),Model1()],[Model2(),Model2(),Model2(),Model2()]]
  // 4.刷新視圖
  tableView.reloadData()
 }

 private func setupTableView() {
  // 在這里實現(xiàn)TableView的代理
  delegate.identifier { (indexPath) -> (String) in
   // 5.確定cell的類型
   return indexPath.section == 0 ? "cell1" : "cell2"
  }.headerHeight { (section) -> (CGFloat) in
   // 6.頭部高度
   return 12.0
  }.footerHeight { (section) -> (CGFloat) in
   // 7.尾部高度
   return 0.01
  }.rowHeight{ (indexPath, data) -> (CGFloat) in
   // 8.行高
   if let model = data as? Model1 {
    return model.height()
   }
   if let model = data as? Model2 {
    return model.height()
   }
   return 44.0
  }.setContentCell { (cell, data) -> (Void) in
   // 9.配置數(shù)據(jù)源
   if let item = cell as? Custom1Cell, let model = data as? Model1 {
    item.textLabel?.text = "Custom1Cell" + model.description
   }
   if let item = cell as? Custom2Cell, let model = data as? Model2 {
    item.textLabel?.text = "Custom2Cell" + model.description
   }
  }.selected {[weak self] (indexPath, data) -> (Void) in
   // 10.點擊事件(這里[weak self]需要防止循環(huán)引用)
   self?.navigationController?.pushViewController(ViewController(), animated: true)
  }
 }
  1. 注冊cell:這一步很重要,這個代理類只支持這種方式加載cell,你在該界面有幾種cell,就需要注冊幾個cell類
  2. 代理: 將代理實例賦值給tableView的代理,這里我將dataSource和delegate統(tǒng)一為delegate了,并且如果有多個TableView,我們還可以創(chuàng)建多個代理實例與其一一對應
  3. 網(wǎng)絡請求:這里是做網(wǎng)絡請求地方,并且將請求后的數(shù)據(jù)保存在代理類中
  4. 刷新視圖
  5. 確定cell的類型:cell是通過它注冊identifier來創(chuàng)建的,所以根據(jù)indexPath來返回相應的cell注冊的identifier即可
  6. 頭部高度:header的高度,可以是定值,也可以根據(jù)section來動態(tài)返回
  7. 尾部高度:footer的高度,可以是定值,也可以根據(jù)section來動態(tài)返回
  8. 行高:這里的行高可以通過data來獲取,這樣利于做高度緩存,也可以通過indexPath來動態(tài)返回
  9. 配置數(shù)據(jù)源:這里可以獲取的已經(jīng)初始化號的cell和其對應的數(shù)據(jù)源,我們只需要將其賦值給cell即可
  10. 點擊事件

上面這些步驟也不是固定的,這里有鏈式編程的思想,有些屬性可以不設(shè)置則會取默認值,當然也可以重復設(shè)置,不過此時后面的會覆蓋前面的

通過上面的方法,我們只需要創(chuàng)建一個CCDataSource實例,就可以在一個方法中將所有的TableView代理實現(xiàn),而且在第5步時,我們就將cell與data對應起來了,后面會減少很多復雜的if else判斷,這不僅減少了代碼量,同時也使實現(xiàn)邏輯更加清晰

Demo地址:https://github.com/cdcyd/CCDataSource (本地下載

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論