项目中需求
:
每摁换行键一次添加一个标签
然后自己刚好在网上找到了一个别人写好的类
:TLTagsControl
问题出现了:怎么取出标签数组??
自己觉得最简单的方法就是在它的基础上添加一个block属性来传值,结果真的传值成功啦
现在分享下自己使用block属性传值的感慨,真的是越用越觉得block神奇好用,但是自己有很多关于block的知识并不是很能说出一二三,只知道怎么使用,以后了解更多再补充!!!
-
首先在TLTagsControl.h中声明block属性
/** * 用来监听最终的标签数组 */ @property (nonatomic, copy) void (^finalTags)(NSArray *array);
-
在TLTagsControl.m的reloadTagSubviews方法最后面执行block监听
NSArray * finalTagArray = (NSArray *)_tags; if (self.finalTags) { self.finalTags(finalTagArray); }
-
在自己建的DZY_EditMarkViewController.m中初始化继承TLTagsControl的_defaultEditingTagControl后监听block并接受tag标签数组
@property (nonatomic,strong) TLTagsControl * defaultEditingTagControl; //声明一个属性 NSMutableArray * tags = [NSMutableArray array]; _defaultEditingTagControl.tags = [tags mutableCopy]; _defaultEditingTagControl.tagPlaceholder = @"343443";//不知道为什么不起作用,有时间研究 if (self.fromPublicStatusVCTags.count > 0) { _defaultEditingTagControl = [[TLTagsControl alloc]initWithFrame:CGRectMake(5, 5, DZY_SCREENWIDTH-10, 36) andTags:_fromPublicStatusVCTags withTagsControlMode:TLTagsControlModeEdit]; }else{ _defaultEditingTagControl = [[TLTagsControl alloc]initWithFrame:CGRectMake(5, 5, DZY_SCREENWIDTH-10, 36) andTags:_allTags withTagsControlMode:TLTagsControlModeEdit]; } _defaultEditingTagControl.showsHorizontalScrollIndicator = NO;//不显示滚动条 [_defaultEditingTagControl reloadTagSubviews]; self.allTags = _defaultEditingTagControl.tags; [_defaultEditingTagControl setTapDelegate:self]; [self.view addSubview:[self defaultEditingTagControl]]; __weak typeof(self) vc = self; _defaultEditingTagControl.finalTags = ^(NSArray *array){ vc.allTags = (NSMutableArray *)array; };
到此就可以在DZY_EditMarkViewController.m中使用标签数组啦!!!
使用总结:
block属性传值时,谁传值,谁声明block属性,然后在.m文件中设置block属性要传的值,最后在要接收值的地方,调用“谁”的block属性,就可以把值传过去啦
2015-9-7 第一次分享关于block的使用
Block使用经验(二)
项目需求:
(消息列表界面)MessageViewController
跳转到(聊天界面)DZY_ChatViewController
,返回MessageViewController
列表时消息未读的提示
消失,界面类似QQ消息界面
附效果图
首先
在
DZY_ChatViewController.h
中声明
haveReadPersonLetterPleaseRefresh
的block
@property(nonatomic,copy)void(^haveReadPersonLetterPleaseRefresh)(BOOL success);
在两个界面有关联的地方实现haveReadPersonLetterPleaseRefresh这个block属性方法
[1]---在
DZY_ChatViewController.m
中的加载数据方法成功后去调用
-(void)loadListDataFromActive{
[RequestNetWork getWithURL:url params:nil isHtml:NO success:^(id json) {
//进入私信详情界面后,通知列表界面刷新(因为取消提示是在该界面一进入就置0)
//请求成功再刷新
if (self.haveReadPersonLetterPleaseRefresh) {
self.haveReadPersonLetterPleaseRefresh(YES);
}
} failure:^(NSError *error) {
NSLog(@"----历史消息-----%@",error);
}];
}
附:
自己刚开始觉得一进入DZY_ChatViewController就可以block调用,结果有时候可以实现,有时候又不能实现,可每次打断点都可以实现,同事提醒下,恍然大悟,网络请求成功才去调用最符合实际,所以最终代码如上
[2]---在
MessageViewController.m
中要跳转的地方调用block,实现关联
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
//取消选中状态
[tableView deselectRowAtIndexPath:indexPath animated:YES];
DZY_ChatViewController *chatView=[[DZY_ChatViewController alloc]init];
chatView.nickName=personLetterNew.authorNickname;
//私信消息已读会通知刷新
__weak typeof(self) vc = self;
chatView.haveReadPersonLetterPleaseRefresh = ^(BOOL success){
NSLog(@"私信消息已读会通知刷新");
if (success == YES) {
[vc.tableView headerBeginRefreshing];
}
[self.navigationController pushViewController:chatView animated:YES];
}
至此,block实现界面通信就结束啦,还是之前说的,block属性的传值,通信,都只需要三步(1-声明,2-声明block的.m文件中实现block,3-与之有关的.m文件也实现block)
2015-09-14晚,第二次分享关于block的使用