提高iOS开发效率的小技巧与思路

先用一张图展示学习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 <UIKit/UIKit.h>

@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开发的大家。

以上是 提高iOS开发效率的小技巧与思路 的全部内容, 来源链接: utcz.com/z/325408.html

回到顶部