iOS开发知识点总结【持续更新】

以下都是自己在iOS开发的过程中遇到的问题,自己总结出来的小知识点。


1.UITableViewCell的contenView的superView在iOS8以上是UITableViewCell,在iOS8以下则不是。所以访问contentView的superView的时候需要注意区分iOS系统版本。


2.程序中一个UITabBarController控制了四个UINavigationController,在某个页面上点击按钮要让tabbar选中某一个baritem,需要先设置tabbar的selectedIndex再将当前的nav popToRootViewController。顺序相反会导致tabbar隐藏。


3.在某个界面上有个UITableView,需要在滑动的时候改变另外一个UIView,所以在代码中添加了如下代理方法:

-(void)scrollViewDidScroll:(UIScrollView *)scrollView

实现了需求。但是如果当UITableView正在滑动的时候pop了当前视图,程序会奔溃。

原因:想已经释放的对象发送了消息。。。。

就是在返回之后,当前视图对象释放了,但是又调用了委托方法。

应该在dealloc方法中将UITableView的委托设置为nil,避免UITableView正在滑动的时候返回会奔溃。

-(void)dealloc

{

    tableView.delegate = nil;

    tableView.dataSource = nil;

//这里要注意,如果项目使用了arc的话,不要调用super dealloc方法。

}


4.十进制数转十六进制数的命令:

echo 'obase=16;1104129754’|bc   其中1104129754是十进制数

这个在分享功能中添加URL Scheme的时候有需要。


5.UITableViewCell自动布局,在cell的最下面自己用UILbel加一个横线。那么添加约束的时候,这个UILabel的宽度要添加跟self的宽度一样。因为如果cell设置了cell.accessoryType =UITableViewCellAccessoryDisclosureIndicator;并且添加UILabel的宽度跟self.contentView的宽度一样的话,就会出现这个UILabel的右边缘到cell上面的向右的箭头的位置就结束了。这说明contentView的右边界是到向右箭头的左边为止的。

像这样的:



6.在自动布局的UITableViewCell向下复现的时候(即UITableView向下滚动的时候,已经出现过的Cell重现出现。)带有一跳一跳的效果。检查发现是因为设置tableView.estimatedRowHeight = 40;导致的。因为我这里有两个高度不同的cell,一个高度是10(作为分隔线的),一个高度根据自适应计算的。如果设置了预估高度的话,高度本来应该为10的cell出现的时候会先设置为40然后又变为10,这就导致了跳动效果。

因此,当UITableView有多个不同高度的UITableViewCell的时候,不应该设置UITableView的estimatedRowHeight属性来只设置一个预估高度值。否则会导致UITableView向下滑动,UITableViewCell复现的时候有一跳一跳的效果。

不过可以通过委托方法- (CGFloat)tableView:(UITableView *)tableView estimatedHeightForRowAtIndexPath:(NSIndexPath *)indexPath来设置不同样式的UITableViewCell的预估高度。


7.自动布局中多行UILabel,需要设置其preferredMaxLayoutWidth属性才能正常显示多行内容。


8.可以使用NSArray或者NSSet的

- (void)makeObjectsPerformSelector:(SEL)aSelector;  

- (void)makeObjectsPerformSelector:(SEL)aSelector withObject:(id)argument;  

这两个相当于for循环的方法来依次让NSArray或者NSSet中的对象执行aSelector方法。


9.给手势添加新的目标对象和方法:- (void)addTarget:(id)target action:(SEL)action

在当前视图上面添加了一个自定义的菜单视图menu,menu上面添加了一个单击手势UITapGestureRecognizer(不是menu的公开属性)来展开和收起菜单,具体事件是写在menu里面的.

现在当前视图上面有文本框,需求是在不改动menu的前提下,点击菜单的时候,释放键盘。

想过给menu新添加一个UITapGestureRecognizer手势来解决这个问题,但是想想它既然已经有了一个单击手势,何必再新添加一个呢。经查阅文档,发现有这么个解决方案:

NSArray *gestureArray = menu.gestureRecognizers;

    for(UIGestureRecognizer *gesturein gestureArray)

    {

        if([gestureisKindOfClass:[UITapGestureRecognizerclass]])

        {

            UITapGestureRecognizer *tapGesture = (UITapGestureRecognizer *)gesture;

            [tapGestureaddTarget:selfaction:@selector(menuTaped)];

            break;

        }

    }

在当前视图中获取自己创建的这个menu上面添加的UITapGestureRecognizer手势,然后给它新增一个目标对象和方法,在方法中处理释放键盘的逻辑。


10.

设置导航的返回按钮标题  需求:只显示返回图标,不显示返回标题

//!!!!:设置导航返回按钮文字的正确姿势!

    UIBarButtonItem *item = [[UIBarButtonItemalloc] initWithTitle:@""style:UIBarButtonItemStylePlaintarget:nilaction:nil];

    self.navigationItem.backBarButtonItem = item;


网上有人说可以用下面的方法,但是实践发现下面这种方法在VC的标题很短的时候不会出现问题,一旦标题变长,这种方法会导致标题向右偏移,看起来很不好。。。。

[[UIBarButtonItemappearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(0, -60)

                                                            forBarMetrics:UIBarMetricsDefault];


偏移效果图如下:



11.页面下拉刷新箭头有时候在加载过程中push进新页面然后再返回的时候收不起来的问题

self.edgesForExtendedLayout=UIRectEdgeNone;是因为self.view addSubView:添加的第一个子视图不是UIScrollView的子类,而没有设置这个导致的。

12.在当前页面A中有一个UITextField文本框,并添加了UITextFieldTextDidChangeNotification通告,当文本框内容改变时进行动态搜索匹配,在收到通知之后改变这个文本框的内容。但是,如果现在push进来了一个新的带有文本框的页面B,当在B中文本框内输入内容之后再返回A,这时候发现A中的文本框的内容是B中文本框所填的内容。

这是因为通告的问题,在监听通告的地方没有判断是不是当前A中的文本框触发的,只需在方法中判断一下即可。

13.tabaritem的标题默认跟它对应的nav的rootviewcontroller的self.title是一样的。如果要tbbaritem的文字跟self.title不一样,可以在rootviewcontroller中设置self.naigationItem.title@“标题”;而不是直接用self.title属性。

14.当给一个UIImageView添加固定宽高约束,但是当加载的网络图片比约束的宽高大很多的时候,显示的图片内容会撑出UIImageView的边界,设置了UIImageView的contentMode也不行。这个给UIImage添加一个Resize分类,并添加一个新的方法:

-(instancetype)resizeToSize:(CGSize)size

{

UIGraphicsBeginImageContext(size);

[selfdrawInRect:CGRectMake(0,0, size.width, size.height)];

UIImage*newImage =UIGraphicsGetImageFromCurrentImageContext();

UIGraphicsEndImageContext();

returnnewImage;

}

对UIImageView的imag进行重绘就不会出现这种情况了。

15.在自定义单元格上面,左边一个UILabel右边对齐显示标题,右边一个UITextField供用户输入内容。给UILabel添加了固定宽度约束,给UITextFiled添加了边距约束。但是当UITextField中输入内容很长的时候会发现UITextFiled会把左边的UILabel挤压到左边(比如UILabel显示的文字是@“姓名”给它加的宽度约束是100,但是实际显示的时候会显示到单元格的最左边,只有刚刚好能显示全@“姓名”的宽度,剩下的单元格宽度都给了UItextFiled。)这种效果不是我们想要的效果,我们想要UILabel固定宽度。只需要将右边的UITextField也添加一个宽度约束即可,添加lessThanOrEqualTo(这里加上cell的宽度减去左边UILabel的宽度以及它们之间的间隔)这样当文本框输入内容很长的时候就不会挤压左边的UILabel了。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值