iOS 實現類似QQ分組樣式的幾種方式

来源:http://www.cnblogs.com/chao8888/archive/2017/07/18/7200421.html
-Advertisement-
Play Games

思路 思路很簡單,對模型數據操作或則控制界面顯示 先看下json部分數據 這種數據對應的一般都是個tableView, 然後根據章節分開,最終界面如下: 分析 這裡採用UITableViewStylePlain樣式,chapterDtoList對應章,subChapterList對應節。章的話我們使 ...


思路


思路很簡單,對模型數據操作或則控制界面顯示

先看下json部分數據

"chapterDtoList": [{
            "token": null,
            "id": 1295,
            "chapterName": "第一章",
            "parentId": 0,
            "chapterLevel": 0,
            "attachmentUrl": "",
            "description": null,
            "startDateTimestamp": null,
            "endDateTimestamp": null,
            "startDate": 1490889600000,
            "endDate": 1491062400000,
            "browseCount": 0,
            "workId": null,
            "chapterStatus": 3,
            "hadRead": 0,
            "subChapterList": [{
                "token": null,
                "id": 1296,
                "chapterName": "第一節",
                "parentId": 1295,
                "chapterLevel": 1,
                "attachmentUrl": "",
                "description": null,
                "startDateTimestamp": null,
                "endDateTimestamp": null,
                "startDate": null,
                "endDate": null,
                "browseCount": 0,
                "workId": null,
                "chapterStatus": null,
                "hadRead": 0,
                "subChapterList": [],
                "classUserReadInfo": []
            }, 

這種數據對應的一般都是個tableView, 然後根據章節分開,最終界面如下:

分析


這裡採用UITableViewStylePlain樣式,chapterDtoList對應章,subChapterList對應節。章的話我們使用headerView來做,節的話我們使用cell來做。然後只需要給headerView添加一個點擊手勢,點擊的時候給對應的模型添加標識,從而去控制章節的收合。

方法一:


對模型數組進行操作,我們可以將返回的json數據轉化為兩個模型數組chapterListArray和tempChapterListArray,通過控制subChapterList的count來實現。界面的模型數據統一使用tempChapterListArray,展開與合併就等價於是否將“章數組“中的”節數組“賦值為nil

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    
    YJTOnlineTaskDetailModel *onlineTaskDetailModel = self.tempChapterListArray[section];

    return onlineTaskDetailModel.subChapterList.count;
}

- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section {
    
    YJTOnlineChapeterCell *headerView = [tableView dequeueReusableCellWithIdentifier:onlineChapeterCell];
    YJTOnlineTaskDetailModel *onlineTaskDetailModel  = self.chapterListArray[section];
    headerView.backgroundColor = [UIColor whiteColor];
    headerView.onlineTaskDetailModel = onlineTaskDetailModel;
    if (section == 0) {
        headerView.tipsLableHeight.constant = 30;
    }else {
        headerView.tipsLableHeight.constant = 0;
    }
    
    
    [headerView whenTapWithBlock:^{
        
        onlineTaskDetailModel.isSelected = !onlineTaskDetailModel.isSelected;
        YJTOnlineTaskDetailModel *detailModel  = self.tempChapterListArray[section];
        if (detailModel.subChapterList == nil) {
            detailModel.subChapterList = onlineTaskDetailModel.subChapterList;
        }else {
            detailModel.subChapterList = nil;
        }
        
        [self.tableView reloadData];
        
    }];
    return headerView;
}

方法二:


上面的方法是通過控制模型數組來實現的,我們也可以採用控制界面的顯示,從而達到我們的要求。既然我們在點擊HeadView的時候已經標記過對應的模型數據是否展開,那麼我們完全可以通過控制界面對應分組的個數來實現。當然也可以通過控制rowHeight來到達效果。相比之下,該方法簡單明瞭些。


- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    
    YJTOnlineTaskDetailModel *onlineTaskDetailModel = self.chapterListArray[section];
    
    return onlineTaskDetailModel.isSelected ? onlineTaskDetailModel.subChapterList.count : 0;
}


 [headerView whenTapWithBlock:^{

        onlineTaskDetailModel.isSelected = !onlineTaskDetailModel.isSelected;
        [self.tableView reloadData];
        
    }];

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 卓聘IM開發背景 智聯卓聘是智聯旗下高端人才招聘平臺,成立快4年了,業務增漲每年以100%速度增漲,業務增漲快在開發和上線速度要求也比較高。 2016年6月提出IM開發需求,7月初上線,開發人員三名,開發時間20多天,後期可以不斷滿足業務需求。前期階段我們考慮網上各種提供IM的雲平臺,這些平臺 ...
  • 本文主要分享一下博主在學習wxpy 的過程中開發的一個小程式。博主在最近有一個監控報警的需求需要完成,然後剛好在學習wxpy 這個東西,因此很巧妙的將工作和學習聯繫在一起。   博文中主要使用到的技術設計到Python,Redis,以及Java。涉及到的技術看似很多,但是主要的語言是基於Pytho... ...
  • Spring Boot 熱部署 實際開發中,修改某個頁面數據或邏輯功能都需要重啟應用。這無形中降低了開發效率,所以使用熱部署是十分必要的。 什麼是熱部署? 應用啟動後會把編譯好的Class文件載入的虛擬機中,正常情況下在項目修改了源文件是需要全部重新編譯並重新載入(需要重啟應用)。而熱部署就是監聽C ...
  • 1 概述 1 概述 軟體架構是一門學問,並且是一門很深邃的學問,從本篇文章開始,我們就來聊聊架構,所用到的主流語言為.NET、Java和php。本篇文章作為架構的開篇文章,主要從廣度上敘述軟體架構的發展與演變,從軟體架構系列第二篇文章開始,將結合具體的產品或項目實例,來與大家分享架構。 本篇文章先簡 ...
  • 使用docker也有段時間了,寫了不少文章與總結,下麵把它整理個目錄出來,方便大家去學習與檢索! docker~學習筆記索引 docker~linux下的部署和基本命令(2017-04-07 22:47) docker~docker-machine的介紹(2017-04-12 12:02) dock ...
  • HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服務端組件、客戶端組件和 Agent 組件,廣泛適用於各種不同應用場景的 TCP/UDP/HTTP 通信系統,提供 C/C++、C#、Delphi、E(易語言)、Java、Python 等編程語言介面。HP-Socket... ...
  • 代碼: #import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any a ...
  • 目前將項目中的leancloud的即時通訊改為環信的即時通訊。當引入easeui的時候 出現方法數超過上限的問題。 搜索一下問題,解決方法很簡單。 這裡簡單記錄一下,順序記錄一下此解決方案導致的另一個問題。 一、解決方法數超過64k的問題 問題描述: 解決方案: 1、app目錄下 build.gra ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...