前言
目前同时维护了三四个项目、每个项目中都有一些共同的与具体业务无关的模块。在公司启动iOS组件化开发新项目之际、逐步的开始封装各个项目中与业务无关的模块。经过多个项目的上线审核与用户校验,不断的进行各个组件完善,分享出来供大家参考。
效果图展示
App Store功能封装需求、业务剥离
APP应用与App Store交互相关的功能有:
- 检测APP应用最新版本、获取应用更新内容、提示用户版本更新。
- 请求评论视图,限制每日最多出现次数、限制每次出现概率、限制最大出现次数避免用户反感。
- 前往App Store评价应用,给以星级评论。
- 系统级APP中应用星级评价。
APP版本更新使用简介
- 自动根据BundleId去App Store获取信息、实现版本更新。
//推荐方法、自动检测APP并弹出更新视图
[ZWCheckVersion zw_autoCheckVersion];
- 自动检测更新、用户自定义提示更新视图。appModel中保存应用最新的基本信息。
//推荐方法、自动检测APP并弹出更新视图。
[ZWCheckVersion zw_autoCheckVersionHandleView:^(ZWAppStoreModel *appModel) {
//需要更新版本、自定义更新视图
}];
- 根据APP应用的iTunesId实现版本检测更新
/**
* 根据应用itunesId版本更新
* appInfo:根据App Store信息自定义处理更新版本视图。
*/
+ (void)zw_checkVersionItunesId:(NSString *)itunesId;
+ (void)zw_checkVersionItunesId:(NSString *)itunesId handleView:(BlockAppStoreInfo)appInfo;
- 判断是否需要更新方法
+ (BOOL)zw_shouldUpdateApp:(ZWAppStoreModel *)model;
- 检测更新版本对比逻辑
- 本地版本与App Store版本位数相同、逐位对比。
- 本地版本与App Store版本位数不同、位数补0后逐位对比。
/**
* 判断是否需要更新
*/
+ (BOOL)zw_shouldUpdateApp:(ZWAppStoreModel *)model {
NSMutableArray *currentVersions = [NSMutableArray array];
NSMutableArray *appStoreVersions = [NSMutableArray array];
[currentVersions addObjectsFromArray:[APP_Version componentsSeparatedByString:@"."]];
[appStoreVersions addObjectsFromArray:[model.version componentsSeparatedByString:@"."]];
NSInteger difference = currentVersions.count - appStoreVersions.count;
if (difference < 0) {
for (NSInteger i = 0; i < labs(difference); i++) {
[currentVersions addObject:@"0"];
}
}else if (difference > 0){
for (NSInteger i = 0; i < labs(difference); i++) {
[appStoreVersions addObject:@"0"];
}
}
for (NSInteger i = 0; i < appStoreVersions.count; i++) {
NSInteger currNum = [currentVersions[i] integerValue];
NSInteger appStoreNum = [appStoreVersions[i] integerValue];
if (appStoreNum > currNum) {
return YES;
}else if (appStoreNum < currNum) {
return NO;
}
}
return NO;
}
请求应用评论视图封装
- 自动检测APP应用的App Store地址、点击前往对应App Store评论页面。
//推荐方法、
/**
* 请求评论视图
* 视图出现逻辑:限制每日最多出现次数、限制每次出现概率
* 限制最大出现次数避免用户反感。
*/
[[ZWActionReview instanceReview] zw_actionRequestReview];
- 根据APP应用的iTunesId请求评论视图
/**
* 请求应用评论弹窗
* 自定义iTunesId
*/
- (void)zw_actionRequestReview:(NSString *)itunesId;
- 直接跳转到应用App Store评论页面
/**
* 前往当前应用的App Store评论界面
*/
- (void)zw_skipToAppStoreReview;
- 前往指定itunesId应用的App Store评论界面
/**
* 前往指定itunesId应用的App Store评论界面
*/
- (void)zw_skipToAppStoreReview:(NSString *)itunesId;
- 评论视图逻辑控制
/**
* 请求评论视图、每次出现的概率(0~1)
* 默认:0.1
*/
@property (nonatomic, assign) CGFloat probabilityDaliy;
/**
* 请求评论视图、每日最多出现的次数
* 默认:每天最多出现一次
*/
@property (nonatomic, assign) NSInteger maxNumDaliy;
/**
* 请求评论视图、一共允许出现的次数
* 默认:一共允许出现最多5次、避免引起用户反感
*/
@property (nonatomic, assign) NSInteger maxTotalNum;
如何使用封装SDK
强烈建议您使用pod导入,节省导入依赖的时间。
- 使用cocoaPods导入(搜索不到请更新本地仓库)
pod 'ZWAppStore'
- 直接将文件夹ZWAppStore拖入工程中
#import "ZWAppStore.h"
源码
源码放在GitHub上,欢迎指正,记得star哦!
【V0.0.5】版本更新记录
- 【修改】: 修改版本对比逻辑、适应版本号位数不一致导致检测更新失败问题。
【V0.0.2】版本更新记录
- 【修改】: 应用检测更新视图图片偏移bug。
【V0.0.1】版本更新记录
- 【新增】: 封装APP应用与App Store交互相关逻辑。