最近一直在忙项目,遇到了个下拉刷新的问题想提出个疑问,还请知情的同学不吝赐教。顺便再放出这段时间忙项目时候的俩小demo。
Demo No.1
要实现的下拉刷新效果是这样的:
我的思路是这样的。使用MJ大大的框架自定义一个Header
然后根据MJRefreshState
的各种状态进行header
界面的调整。可是写完之后发现当header
比较高的时候MJRefreshStatePulling
这个手指松开就可以进行刷新的状态监测不到。目前只实现了这样的效果
Demo已放在Github,希望知道的同学,给解惑一下。在下感激不尽!谢谢。
Demo No.2
由于公司项目是电商,收获地址这块就用的是三级城市列表。因此就从项目中摘了出来,简单写了一下,效果如图:
写的过程中,比较坑的是添加收货地址时候后台告诉我要传省、市、区(县)对应的ID,并且收获地址列表返回数据是对应的ID。顿时都无语了,强烈要求他在列表里直接返回对应的省市区(县)名字了。不然三个大数组,返回的上千条数据,列表和详情都转模型,再遍历,这要遍历到啥时候了。。。
关键点是显示到界面时候的逻辑判断,也就是取数据的这一块。。。
#pragma mark - 点击确定按钮事件
/**
点击确定按钮事件
@param sender sender
*/
- (void)completionButtonAction:(UIButton *)sender
{
NSString *provinceName = @"";
NSString *cityName = @"";
NSString *regtionName = @"";
NSInteger _provinceID = 0;
NSInteger _cityID = 0;
NSInteger _regtionID = 0;
HPAddAddressPickerModel *pickerModel;
HPAddAddressCityModel *cityModel;
HPAddAddressRegionModel *regtionModel;
if (_provinceArray.count > 0) {
if (_firstCurrentIndex > 0) {
if (_firstCurrentIndex - 1 < _provinceArray.count) {
pickerModel = _provinceArray[_firstCurrentIndex - 1];
//获取省
provinceName = pickerModel.name;
_provinceID = pickerModel.provinceID;
}
}
}
if (_cityArray.count > 0) {
if (_secondCurrentIndex > 0) {
if (_secondCurrentIndex - 1 < _cityArray.count) {
cityModel = _cityArray[_secondCurrentIndex - 1];
//获取市
cityName = cityModel.name;
if (cityModel.parent_id == pickerModel.provinceID) {
_cityID = cityModel.city_id;
}
}
}
}
if (_regionArray.count > 0) {
if (_thirdCurrentIndex > 0) {
if (_thirdCurrentIndex - 1 < _regionArray.count) {
//获取区
regtionModel = _regionArray[_thirdCurrentIndex - 1];
regtionName = regtionModel.name;
if (regtionModel.parent_id == cityModel.city_id) {
_regtionID = regtionModel.region_id;
}
}
}
}
NSLog(@"省%ld 市%ld 区%ld",_provinceID,_cityID,_regtionID);
if (_provinceID == 0) {
// [STTextHudTool showText:@"请选择正确的省份" withSecond:1];
return;
}else if (_cityID == 0) {
// [STTextHudTool showText:@"请选择正确的城市" withSecond:1];
return;
}else if (_regtionID == 0){
// [STTextHudTool showText:@"请选择正确的区(县)" withSecond:1];
return;
}
NSDictionary *params = @{
@"province": @{
@"provinceName":provinceName,
@"provinceID":kStringIntegerFormat(_provinceID)
},
@"city": @{
@"cityName":cityName,
@"cityID":kStringIntegerFormat(_cityID)
},
@"regition":@{
@"regtionName":regtionName,
@"regitionID":kStringIntegerFormat(_regtionID)
},
};
if (_completion) {
_completion(params);
}
}
Demo No.3
公司项目首页抢购商品cell
上需要根据后台返回的结束时间加一个倒计时。现在也把这块给抽出来了,效果如图:
实现思路就是先写了个NSString+Extension
的分类,然后把后台返回的结束时间转化为倒计时一共的时间。然后用GCD
写个一秒钟的倒计时。每1秒钟给cell
上的UILable
赋值一次。虽然性能不会很好,但是能力有限,想不到更好的方式了。有其他写法的童鞋,也请多多指教~
关键代码在这里:
- (void)viewDidLoad {
[super viewDidLoad];
WS(weakSelf);
[self.tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"reuseIdentifier"];
[self.homePageViewModel countDownWithPER_SECBlock:^{
[weakSelf updateTimeInVisibleCells];
}];
}
#pragma mark - Custom Method
- (void)updateTimeInVisibleCells
{
//遍历当前 屏幕可见cell,对cell上的倒计时一秒钟赋值一次
[self.tableView.visibleCells enumerateObjectsUsingBlock:^(__kindof UITableViewCell * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
if ( [obj isKindOfClass:[UITableViewCell class]]) {
// [NSString stringToCurtDownString:string] 这个是分类方法
obj.textLabel.text = [NSString stringToCurtDownString:self.homePageViewModel.rushArray[obj.tag]];
}
}];
}