关于封装思路:
1.页面过于冗余的时候可以采用分类形式,或者为了方便使用某些自定义的方法采用分类为系统控件添加方法。
比如路由编写的时候,Nav为了方便使用,采用VC的分类形式。直接使用[vc gotoPage:pageName]
2.相关工具或者抽离出来的组件,可以作为对象考虑分离问题。比如写路由的时候,路由的nav的参数拆分一个Model类,便于方法看起来简洁。同理,路由的相关参数数据也可以封装一个Data类。如果里面有很多的数据相关操作,不牵扯到视图可以再封装出一个manger或者Utility类。
3.工具类的方法暴露出来的尽量写的全面,多样化,工厂方法形式。
4.可以对APPdelegate进行抽离分类,不同分类处理不同的业务。
5.对Nav push的栈做最大限制,如果栈中vc数量过多,则自动剔除最开始的一个(root push的第一个vc)
6.在ViewController的分类中绑定某个vc和某个字典。 这一点我另一篇文章分类里面写过,不过发现一个新的用途。页面传值的另一种方式
- (void)setCallBackCommandForPageNavigation:(NSString *)command {
objc_setAssociatedObject(self, ((__bridge void*)callBackCommandKeyForPageNavigation),command, OBJC_ASSOCIATION_RETAIN);
}
7.类中定义的协议,枚举,宏。如果比较特殊或者比较多,都可以新建一个.h放置
8.可变集合,数组,字典等等 插入objc前要做非空判断,容器类最好使用泛型,尽可能少用可变类型
9.通知要使用全局的字符串定义,采用组合形式。最好是加上didWill这一类的代表性关键字。参照系统的定义方式:
比如:NSTextView Did ChangeSelection Notification
10.在大量创建临时变量的地方使用autoreleasepool,比如for,遍历
11.在init和dealloc阶段,self是一个不完整的对象。所以不允许在这两个方法中使用self调用属性,用_调用,但是外面正常方法中建议使用self,防止不调用get方法。
12.dealloc并不能准确释放计时器类Timer,因为如果有其他地方强引用类,或者timer强引用其他object根本不会走dealloc。所以有必要手动将其置为nil
13.NSCopying协议的对象必须用copy修饰,NSString,NSURL,block,NSArray推荐使用copy。UIView这一类用strong,strong引用子类,weak引用parent
14. 小助手option+command+/即可自动插入注释 完整格式的注释
15. x=a?a:b 只要写成x=a?:b
16. 长条件if判断用bool在外部替代
比如:if(a == (B +c/d) || [aa isEqualToString:@"name"]) 可以把里面的判断条件摘出来做一个bool值
17.*之前出了一个问题,本地化的时候,由于没有了网络请求的限制,视图创建的速度就跟不上进程的速度了。导致有可能在调用self.view 的时候调用不到而报错。所以在使用除了viewDidLoad之外的一些方法里调用self.view 的时候一定要注意,这个时候他是否已经被创建出来了
18.在使用固定格式的dateFormatter时候,需要设置setLocale为"en_US_POSIX",防止一些不同日历下格式异常,其实和“en_US”是一样的,但是系统更推荐用上面那个。当然,大部分人直接用的"zh_CN"
NSDate* now = [NSDate date];
NSDateFormatter* format = [[NSDateFormatter alloc] init];
format.locale = [[NSLocale alloc] initWithLocaleIdentifier:@"en_US_POSIX"];
19.不建议将UIView类的对象加入到NSDictionary, NSSet,如有需要可以添加到NSMapTable 和 NSHashTable。
NSDictionary,NSSet会对加入的对象做strong引用,而NSMapTable、NSHashTable会对加入的对象做weak引用。
20. 取substring的时候要考虑emoji字符的问题,防止截到中间crash
- (NSString *)yySubstringToIndex:(NSUInteger)index
{
//越界判断
NSRange wRange = [self rangeOfComposedCharacterSequencesForRange:NSMakeRange(0, index)];
return [self substringWithRange:wRange];
}