内容简介:iOS开发中的Self-Manager设计模式
本文的灵感来自 http://blog.sunnyxx.com/2015/12/19/self-manager-pattern-in-ios/
这种模式的意义就是自己的事情自己做完,不要去给别人添麻烦,让你的功能纯粹点。
举个栗子 :你要实现一个分享功能。可能你很多地方都需要分享,那你不可能每个地方都去写一遍对不对,所以这时候你需要把分享功能抽离出来对不对,让它纯粹。
+ (void)wxShareWithImages:(NSArray *)images shareTitle:(NSString *)shareTitle shareContent:(NSString *)shareContent shareURLString:(NSString *)shareURLString response:(KZWResponseCallback)response;
你只要单独出来一个shareservice这样你不管在哪分享只要调用这个方法就可以了什么都不用管。然后你就可以发现你可以把你app的很多服务抽出来,减少冗余代码。 纯粹 !
再举个栗子 就是作者原文的栗子,为什么我要举相同的栗子呢,因为我还有话说:微博的头像到处都有,都需要点击头像跳转个人中心,以及包括头像的各种大v特效等。
代码是这样的:
- (void)selfManagedConfigureWithAvatarURL:(NSURL *)URL VIPInfo:(id)info UID:(NSString *)UID { [self configureWithAvatarURL:URL VIPInfo:info tapped:^{ // 假设 App 结构是 Root -> TabBar -> Navigation -> ViewController UITabBarController *tabBarControler = (id)[UIApplication.sharedApplication.delegate.window.rootViewController; UINavigationController *navigationController = tabBarControler.selectedViewController; // 创建用户信息 View Controller FDUserProfileViewController *profileViewController = [FDUserProfileViewController viewControllerWithUID:UID]; [navigationController pushViewController:profileViewController animated:YES]; }]; }
大家会发现一个问题,跳转写在view里了。
大家都知道跳转的方法需要调用controller,在view里是没有的,需要去声明很不方便对不对,这时候你就需要router,各种跳随便跳,哈哈哈。让你的self-mannage更纯粹。
最后举个栗子 :大家的app里都有很多webview对不对,是不是一个webview声明了一个controller。其实不需要,只需要一个controller,把url传进去就重新打开一个webview就不需要那么多controller了,然后我们可以在里面把router应用进去。这样你就可以做到,webview的导航栏,是否需要返回,是否需要titler,是否需要传完整的url还是只需要传path,以及测试还是线上环境等都成为可配。这样是不是很爽,哈哈哈。让你的self-mannage更纯粹。
我这里也只是对这种 设计模式 的一个扩展,抛砖引玉一下,希望你也能爽。
以上所述就是小编给大家介绍的《iOS开发中的Self-Manager设计模式》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 设计模式-享元设计模式
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
高性能JavaScript
Nicholas C.Zakas / 丁琛、赵泽欣 / 电子工业出版社 / 2010-11 / 49.00元
如果你使用JavaScript构建交互丰富的Web应用,那么JavaScript代码可能是造成你的Web应用速度变慢的主要原因。《高性能JavaScript》揭示的技术和策略能帮助你在开发过程中消除性能瓶颈。你将会了解如何提升各方面的性能,包括代码的加载、运行、DOM交互、页面生存周期等。雅虎的前端工程师Nicholas C. Zakas和其他五位JavaScript专家介绍了页面代码加载的最佳方......一起来看看 《高性能JavaScript》 这本书的介绍吧!
JS 压缩/解压工具
在线压缩/解压 JS 代码
RGB CMYK 转换工具
RGB CMYK 互转工具