先用一张图展示学习iOS开发应该掌握的知识体系:
1.全图片作为背景的时候,可能遇到的问题。,滑回的时候,图片停留了一会才滑回去。
原因: 这种界面一般使用一般用imageView的第三种填充方式。
这种填充方式可以让图片不被压缩变形的前提下,尽可能去填充整个控件,但是设置这个枚举的填充方式的时候,记得按照下图这样设置,将超出控件范围的给切割掉
设置约束的时候,记得选择currentview的那个对象
2.设备适配的问题
还是上面这张图片,按照设计在6p上面来设置自动约束,约好后,在5s上面的时候,下面的爱心在自动约束的设置下面和专业设置太近,这时候挺影响美观的,这时候第一反应当然是根据设备来进行调整,但是我觉得这里完全可以使用下面这种方式来进行判断设置
CGFloat top = 0; CGFloat left = 0; CGFloat bottom = 0; CGFloat right = 0; if ([UIScreen ff_screenSize].width == 375) { top = 80; left = 70; bottom = 31; self.titleLabel.fOnt= [UIFont systemFontOfSize:18]; self.englishLabel.fOnt= [UIFont systemFontOfSize:20]; self.introduceLabel.fOnt= [UIFont systemFontOfSize:14]; right = 33; }else if ([UIScreen ff_screenSize].width == 414){ bottom = 31; top = 88; left = 84; right = 33; }else if ([UIScreen ff_screenSize].width == 320){ self.titleLabel.fOnt= [UIFont systemFontOfSize:16]; self.englishLabel.fOnt= [UIFont systemFontOfSize:18]; self.introduceLabel.fOnt= [UIFont systemFontOfSize:13]; self.introduceTop.cOnstant= 8; top = 70; left = 44; bottom = 24; right = 28; } self.collectionButtonLeft.cOnstant= right; self.chineseLabelTop.cOnstant= top; self.introlduceLeft.cOnstant= left; self.collectionButtonbottom.cOnstant= bottom; [self.view setNeedsLayout];
记得修改约束后调用一下[self.view setNeedsLayout];
这也是很关键的一点,不调用没有效果。
3.数字动画效果
在涉及到数字比较大的数据的时候可以采取这个效果来做,效果感人。
想实现这种效果也比较简单。
@property (weak, nonatomic) IBOutlet UICountingLabel *tuitionLabel; weakSelf.tuitionLabel.text = self.tuitionForAcademyModel.tuition; NSInteger grade = [self.tuitionForAcademyModel.tuition integerValue]; weakSelf.tuitionLabel.format = @"%d%"; [weakSelf.tuitionLabel countFromZeroTo:grade];
最重要的一步是设置format,不然他会跑小数的。
4.label文字间距如何调整
- (void)configureContentLabelText { NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc]initWithString:@"Label"]; long number = 5; CFNumberRef num = CFNumberCreate(kCFAllocatorDefault,kCFNumberSInt8Type,&number); [attributedString addAttribute:(id)kCTKernAttributeName value:(__bridge id)num range:NSMakeRange(0,[attributedString length])]; CFRelease(num); self.label.attributedText = attributedString; }
效果如下,字的间距被拉开了
5 . 登录思路
a.用户进入app后,在使用app的过程中,进行需要登录的操作。
b.这时候调用的后台接口一般需要带上token参数。这时候因为用户没有登录,没有token,所以在这里进行判断本地是否持久化了token.
c.本地没有持久化token,所以自动弹出登录框,让用户进行登录
d.用户登录完毕后将相关数据,特别是token进行本地持久化
小细节:
a.每次启动app的时候可以将token 进行io操作读取出来,保存在单例里面,这样就不用重复的去进行耗费性能的io操作
b.因为项目中自定义控件必不可少,在控件级别的页面,需要使用到需要登录的操作,这时候就需要发送通知给对应的控制器来present login控制器,因为控制器级别才能弹出控制器,这样一来,会产生大量的通知操作,建议可以将login写在window上面(这里因为项目工期紧,发现这个问题的时候已经不好处理,希望后来的兄弟们切记)
c.需要token参数的接口,token参数错误,这时候需要后台给一个统一的回调,这样方便集中起来处理
6 . 账号互踢的思路
千万不要尝试在单个页面去处理。
思路如下:
1.需要在登录登出的发送通知到各个控制器,并在通知里面进行各个控制器的初始化操作。
2.在调用需要登录才能操作的接口的时候,后台进行判断给你一个token 参数失效的回调
3.作为一个合理的项目框架,总该有一个AFN的封装吧!在封装的AFN里面进行统一判断,如下图。(因为每个后台处理方式不一样,代码就上图吧,给你们代码也复用不了。)
4.这个通知发送到了UITabBarController,进行让用户重新登录处理
#import@interface WXMainController : UITabBarController @end
#pragma mark -监听账号互踢,这时候先退出登录,然后回到首页 - (void)addNotification{ WS(weakSelf); // [[NSNotificationCenter defaultCenter] postNotificationName:KMutualKickNotification object:nil]; [[NSNotificationCenter defaultCenter] addObserverForName:KMutualKickNotification object:nil queue:nil usingBlock:^(NSNotification * _Nonnull note) { [weakSelf alertWindow]; }]; } #pragma mark-弹出框选择界面 - (void)alertWindow{ if (!self.isShow) { self.isShow = YES; UIAlertView *alter = [[UIAlertView alloc] initWithTitle:@"" message:@"您的账号已在其他设备登录,现在您已经处于退出登录状态" delegate:self cancelButtonTitle:@"确定" otherButtonTitles:nil]; [alter show]; } } #pragma mark-弹出框选择界面的代理方法,点击确定就弹出登录框 - (void)alertView:(UIAlertView *)alertView clickedButtonAtIndex:(NSInteger)buttonIndex{ if (buttOnIndex== 0) { WXLoginController * loginCOntroller= [WXLoginController showLoginContoller:NO andIsShowColse:NO]; [self presentViewController:loginController animated:YES completion:nil]; self.isShow = NO; } }
任何事情都有方法和技巧,单没有捷径,IOS开发也不例外,脚踏实地从实践中发现方法,熟练后就有技巧。希望本文能够帮助的学习IOS开发的大家。