• Stars
    star
    901
  • Rank 50,699 (Top 1.0 %)
  • Language
    Objective-C
  • License
    MIT License
  • Created over 9 years ago
  • Updated about 6 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

一行代码完成“空TableView占位视图”管理

CYLTableViewPlaceHolder【一行代码完成“空TableView占位视图”管理】

![pod-v1.0.6](https://img.shields.io/badge/pod-v1.0.6-brightgreen.svg) ![Objective--C-compatible](https://img.shields.io/badge/Objective--C-compatible-orange.svg) ![platform-iOS-6.0+](https://img.shields.io/badge/platform-iOS%206.0%2B-ff69b4.svg)

导航

  1. 与其他框架的区别
  2. 集成后的效果
  3. 使用CYLTableViewPlaceHolder
  4. 运行Demo
  5. 适用于多种应用应用场景
  6. 网络故障
  7. 暂无数据

与其他框架的区别

- 特点 解释
1 轻量级、无污染 基于 UITableView 分类,无污染,比基于子类化、继承的框架更加轻量级
2 低耦合 自定义占位视图的可自行实现,通过协议传递,耦合性极低。
3 简单,无学习成本 一行代码完成,仅需使用 cyl_reloadData 代替 reloadData 即可。自动检测是否需要 addSubviewremoveFromSuperview ,省去学习繁琐的 add 和 remove 的调用时机。
4 使用方法简单 CYLTableViewPlaceHolder 基于 dataSource 数据源,所以只需操作 dataSource 数据源,即可完成占位视图的 addSubviewremoveFromSuperview 的时机,更加直观。搭配 MJRefresh 使用十分方便,demo 中也给出了搭配使用方法。
5 支持CocoaPods 容易集成

(学习交流群:465239521)

集成后的效果

集成后的效果

使用CYLTableViewPlaceHolder

三步完成:

  1. 第一步:使用cocoaPods导入CYLTableViewPlaceHolder
  2. 第二步:遵循协议
  3. 第三步:使用cyl_reloadData代替reloadData

第一步:使用CocoaPods导入CYLTableViewPlaceHolder

Podfile 中进行如下导入:

pod 'CYLTableViewPlaceHolder'

然后使用 cocoaPods 进行安装:

如果尚未安装 CocoaPods, 运行以下命令进行安装:

gem install cocoapods

安装成功后就可以安装依赖了:

建议使用如下方式:

# 禁止升级CocoaPods的spec仓库,否则会卡在 Analyzing dependencies ,非常慢 
pod update --verbose --no-repo-update

如果提示找不到库,则可去掉 --no-repo-update

pod update

第二步:遵循协议

导入头文件

#import "CYLTableViewPlaceHolder.h"

遵循协议

@interface ViewController ()<CYLTableViewPlaceHolderDelegate>

实现协议方法:

仅一个必须实现的协议方法:

创建一个自定义的占位视图并返回

@required
/*!
@brief  make an empty overlay view when the tableView is empty
@return an empty overlay view
*/
- (UIView *)makePlaceHolderView;

这里注意两点:

  1. CYLTableViewPlaceHoldercyl_reloadData方法内部会重新将该占位视图的 frame 进行设置,设置为与当前的的 TableView 一致:包括 xy 坐标和宽高。防止 TableView 位置或尺寸的变更。
  2. 以上步骤,包括遵循协议实现协议方法,既可以在自定义的 TableView 中去做,也可以在 TableView 的代理中去做。

既可以让代理遵循协议,实现协议方法:

@interface ViewController ()<CYLTableViewPlaceHolderDelegate>

也可以让自定义的 TableView 遵循协议,实现协议方法:

@interface MyTableView ()<CYLTableViewPlaceHolderDelegate>

这里推荐在自定义的 TableView 中实现,以降低耦合性,同时也可以为 Controller 瘦身。

占位视图的点击事件等,请自行在 - (UIView *)makePlaceHolderView; 中所创建的 View 中实现。

另外,占位视图默认的设置是不能滚动的,也就不能下拉刷新了,但是如果想让占位视图可以滚动,则需要实现下面的可选代理方法。

@optional
/*!
@brief enable tableView scroll when place holder view is showing,it is disabled by default.
@attention There is no need to return  NO , it will be NO by default
@return enable tableView scroll, you can only return YES
*/
- (BOOL)enableScrollWhenPlaceHolderViewShowing;

第三步:使用cyl_reloadData代替reloadData

使用方法:

仅需使用 cyl_reloadData 代替 reloadData 即可。

   [self.tableView cyl_reloadData];

注意: cyl_reloadData 内部已经实现了 [self.tableView reloadData]; 方法,请避免重复调用。

运行Demo

demo 的刷新组件使用的是 MJRefresh,所以需要导入相应的 CocoaPods 库

# 打开终端,进入 clone 的文件夹
cd /Users/YourUserName/Documents/CYLTableViewPlaceHolder
# 如果提示找不到库,则可去掉 --no-repo-update
pod install --verbose --no-repo-update 
open CYLTableViewPlaceHolder.xcworkspace

适用于多种应用应用场景

CYLTableViewPlaceHolder 是基于 dataSource 数据源是否为空,所以只需操作 dataSource 数据源,即可完成占位视图的 。只要为空就会触发。并且每次在操作占位视图的 addSubviewremoveFromSuperview时,每次都会将旧的销毁,并触发- (UIView *)makePlaceHolderView` 创建一个新的视图。如果在该方法中进行 if 判断,也就能适用于不同的场景。

  1. 网络故障 1. 网络不可用,禁止重新加载
  2. 暂无数据

网络故障

适用于那些造成 dataSource 为空的原因只能是网络故障,比如首页、团购列表、商品列表等

比如

携程 网络故障 携程 网络故障 携程 网络故障
应用场景之加载失败--携程 应用场景之加载失败--携程 应用场景之加载失败--携程

代码实现时直接返回网络故障占位视图,用伪代码表示则是:

- (UIView *)makePlaceHolderView {
       return NetNotAvailableView;
}

网络不可用,禁止重新加载

如果此时检测到网络断开可以禁止用户刷新的行为,比如:

QQ空间 苏宁易购 嘟嘟美甲
应用场景之加载失败 应用场景之加载失败 应用场景之加载失败

暂无数据

适用于那些造成 dataSource 为空的原因不仅有网络故障,也可能是确实是服务端也没有数据,这种场景下需要判断下当前网络再返回占位视图,比如:

App 暂无数据 网络故障
百度传课 应用场景之暂无数据 应用场景之加载失败
暂无数据 暂无数据(美团)
应用场景之暂无数据 应用场景之暂无数据

代码实现,用伪代码表示则是:

- (UIView *)makePlaceHolderView {
   if (NetNotAvailable) {
       return NetNotAvailableView;
   } else {
       return NoDataView;
   }
}

网络不可达场景

  • | 应用场景之加载失败 | --- -------------|-------------|------------- 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败 | 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败| 应用场景之加载失败 应用场景之加载失败 | 应用场景之加载失败|应用场景之加载失败 应用场景之加载失败| 应用场景之加载失败 |应用场景之加载失败

(更多iOS开发干货,欢迎关注 微博@iOS程序犭袁


Posted by 微博@iOS程序犭袁
原创文章,版权声明:自由转载-非商用-非衍生-保持署名 | Creative Commons BY-NC-ND 3.0

More Repositories

1

iOSInterviewQuestions

iOS interview questions;iOS面试题集锦(附答案)--学习qq群或 Telegram 群交流 https://github.com/ChenYilong/iOSBlog/issues/21
Swift
9,244
star
2

CYLTabBarController

[EN]It is an iOS UI module library for adding animation to iOS tabbar items and icons with Lottie, and adding a bigger center UITabBar Item. [CN]【中国特色 TabBar】一行代码实现 Lottie 动画TabBar,支持中间带+号的TabBar样式,自带红点角标,支持动态刷新。【iOS13 & Dark Mode & iPhone XS MAX supported】
Swift
6,860
star
3

iOS9AdaptationTips

iOS9适配系列教程(iOS开发学习交流群: https://github.com/ChenYilong/iOSBlog/issues/21)
Objective-C
4,477
star
4

ParseSourceCodeStudy

Facebook开源的Parse源码分析【系列】
Objective-C
2,876
star
5

CollectionViewClassifyMenu

CollectionView做的两级菜单,可以折叠第二级菜单
Objective-C
1,535
star
6

iOSBlog

微博@iOS程序犭袁 的blog
Objective-C
1,117
star
7

iOS10AdaptationTips

for iOS10 in [ObjC, Swift, English, 中文] {...}
Objective-C
642
star
8

iOS11AdaptationTips

for iOS11 in [ObjC, Swift, English, 中文] {...} -- iOS11适配系列教程
486
star
9

WebRTC

WebRTC for iOS
Objective-C
428
star
10

CYLDeallocBlockExecutor

Hello block,byebye dealloc!一行代码代替dealloc完成“self-manager”
Objective-C
253
star
11

CYLSearchViewController

模仿iPhone短信聊天里的搜索框样式,点击搜索后,搜索框平滑移动到导航栏上。
Objective-C
176
star
12

iOS13AdaptationTips

iOS13 AdaptationTips
175
star
13

CYLExternalURL

模仿 《简书 App》 的效果:在html中跳转到App中的对应页面,并能从App跳转到原来的网址
Objective-C
117
star
14

iOS12AdaptationTips

iOS12AdaptationTips
86
star
15

CYLChatKit

仿微信高度自定义UI、集成第三方IM SDK。An IM App UI Framework, support sending text, pictures, audio, video, location messaging, managing address book, more interesting features.
Objective-C
71
star
16

iOSDevelopmentTips

iOS开发笔记
Objective-C
67
star
17

SMSCodeButton

可用作短信验证码的倒计时 Button
Objective-C
52
star
18

CYLCURLNetworking

Networking based on curl
Objective-C
48
star
19

CYLTabBarControllerDemoForWeib

CYLTabBarController 的示例DEMO
Objective-C
34
star
20

LineLayout

苹果官方展示UICollectionView 用法的 Demo
Objective-C
22
star
21

CYLHttpTest

【调接口神器】可将 XML 或 JSON 数据解析并转换为Plist文件存在本地,方便调接口。
Objective-C
21
star
22

CYLWebViewController

WebViewControllerDemo,可App类似 Safari 的效果,能随着滑动隐藏底部工具栏
Objective-C
20
star
23

CYLTableViewRowAction

Use UITableViewRowAction as if it supports iOS7+.
Objective-C
11
star
24

XcodeMissingTemplates

Add⓵Empty Application.xctemplate ⓶Objective-C category.xctemplate ⓷Objective-C class extension.xctemplate ⓸Objective-C protocol.xctemplate
Objective-C
11
star
25

CYLTabBarController-Swift

Swift版本的CYLTabBarController ( https://github.com/ChenYilong/CYLTabBarController ),支持 CocoaPods 。
11
star
26

CYLBusinessCardButton

重写 UIButton ,使用一个 UIButton,显示一张名片,内含有三个 Label 一个头像。
Objective-C
11
star
27

Flutter101

Flutter101
Dart
8
star
28

CYLSwipeBetweenControllers

手势切换控制器,动画流畅,有过度效果。
Objective-C
8
star
29

HandleViewControlEventsWithBlock

展示如何使用runtime和手势两种方式为UIView添加类似UIButton的addTarget-action-forControlEvents-事件
Objective-C
7
star
30

ChenYilong

2
star
31

ReactNativeDemo

Objective-C++
2
star