用XTTable快速而干凈處理TableView

請支持原創, 如需轉載, 請注明出處@TEASON

之前的文章里我有說要寫關于UITableView見解的兩篇, 算是展開討論吧, 這是第一篇, 第二篇下集鏈接在此.

說在前面:

最近有個MVVM模式非常火熱, 相信它的出現是為了模塊化iOS開發, 其實在我看來,它始終還是MVC模式, 只是一個變種罷了.MVVM的精髓在于數據動態綁定通常用RAC, 也就是ViewModel, 但問題是既然用了RAC和ViewModel,其實也是Model層的擴展。


與其專注于說明 MVVM 的來歷,不如讓我們看一個典型的 iOS 是如何構建的,并從那里了解MVVM我們看到的是一個典型的 MVC設置。Model呈現數據,View呈現用戶界面,而 View Controller調節它兩者之間的交互。 稍微考慮一下,雖然View 和 View Controller是技術上不同的組件,但它們幾乎總是手牽手在一起,成對的。你什么時候看到一個 View能夠與不同 View Controller配對?或者反過來?所以,為什么不正規化它們的連接呢? 這更準確地描述了你可能已經編寫的 MVC代碼。但它并沒有做太多事情來解決iOS應用中日益增長的重量級視圖控制器。在典型的 MVC 應用里,許多邏輯被放在View Controller里。它們中的一些確實屬于View Controller,但更多的是所謂的“用于顯示的邏輯”,以 MVVM 屬術語來說——就是那些從Model轉換數據為 View可以呈現的東西的事情,例如將一個NSDate 轉換為一個格式化過的 NSString。 我們的圖解里缺少某些東西。某些使我們可以放置所有表示邏輯的東西。我們打算將其稱為“View Model”——它位于 View/ControllerModel之間: 看起好多了!這個圖解準確地描述了什么是 MVVM:一個 MVC 的增強版,我們正式連接了視圖和控制器,并將表示邏輯從 Controller 移出放到一個新的對象里,即 View ModelMVVM 聽起來很復雜,但它本質上就是一個精心優化的 MVC架構,而 MVC你早已熟悉。


好了, 引言說完了, 這是一個鋪墊 . 如果你認為下圖右邊的方法全部放在ViewController里便于日后維護和擴展的話 . 你大可固執己見然后點擊瀏覽器右上角的"×" ...

屏幕快照 20151214 下午35800png

當然, 關于瘦身ViewController有很多方面 . 然而今天我們講講從Controller中分離TableView的表示邏輯 . 為什么引言MVVM設計模式, 也是闡述這個主要思想是相通的 . 就是把"邏輯部分"盡量移到Model層, 你可以認為它是一個中間層 , 所謂"邏輯部分"可以是各種delegate,網絡請求,緩存,數據庫,coredata等等等等 , 而controller正是用來組織串聯他們 .使得整個程序走通 .

所以我把對TableView和CollectionView的布局進行了封裝,做了一個庫XTTable,可以看一下現在我是如何使用TableView或者CollectioView的。

正文

一行代碼完成注冊, 兩行代碼完成初始化配置

    [MyCell xt_registerNibFromTable:self.table] ;
    [self.table xt_setup] ;

    self.table.delegate = self ;
    self.table.dataSource = self ;
    self.table.xt_Delegate = self ; 

datasource and delegate

瘦身后的cellForRowAtIndexPath只需要兩行

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
// 僅僅兩行. 將model和cell的display綁定
     MyCell *cell = [MyCell xt_fetchFromTable:tableView] ;
     [cell xt_configure:self.list[indexPath.row] indexPath:indexPath] ;
 return cell;
}

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {
     return [MyCell xt_cellHeightForModel:self.list[indexPath.row]] ;
}

Reloader

這里是上拉和下拉加載的處理,也只需要處理datasource

- (void)tableView:(UITableView *)table loadNew:(void (^)(void))endRefresh {
     // do load new here ...
     endRefresh() ; // 加載之后調用結束刷新callback
}

- (void)tableView:(UITableView *)table loadMore:(void (^)(void))endRefresh {
     // do load more here ...
     endRefresh() ; // 加載之后調用結束刷新callback
}

Cell config

得到datasource繪制Cell

- (void)xt_configure:(id)model indexPath:(NSIndexPath *)indexPath {
    [super xt_configure:model indexPath:indexPath] ;
    // 處理繪制
    MyObj *myObj         = (MyObj *)model;
    _lbTitle.text  = myObj.name;
    _lbHeight.text = [NSString stringWithFormat:@"my Height is : %@", @(myObj.height)];
    self.backgroundColor = indexPath.row % 2 ? [UIColor greenColor] : [UIColor brownColor];
}

+ (CGFloat)xt_cellHeightForModel:(id)model {
    return ((MyObj *)model).height;
}

當然如果你想深入理解, 可以看源代碼, 我傳到了github, 點我下載 , 喜歡的話去那加個??, 對開源者是莫大的鼓勵 . 任何疑問或建議, 歡迎, 我會看你們的留言 .

介紹MVVM Lighter View Controllers Table View Programming Guide Cocoa Core Competencies: Controller Object

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,501評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,673評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,610評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,939評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,668評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,004評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,001評論 3 449
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,173評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,705評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,426評論 3 359
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,656評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,139評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,833評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,247評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,580評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,371評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,621評論 2 380

推薦閱讀更多精彩內容